Socket
Socket
Sign inDemoInstall

css-select-parse5-adapter

Package Overview
Dependencies
1
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    css-select-parse5-adapter

An adapter for the css-select package for querying trees returned by the parse5 package.


Version published
Weekly downloads
489
increased by87.36%
Maintainers
1
Install size
35.9 kB
Created
Weekly downloads
 

Readme

Source

css-select-parse5-adapter

An adapter for css-select that allows you to query parse5 generated ASTs.

Installation

You'll need css-select and parse5 for this adapter to be of any use, so install all three packages:

npm install \
    css-select \
    css-select-parse5-adapter \
    parse5

Usage

const {parse,serialize} = require('parse5');
const {parse5Adapter} = require('css-select-parse5-adapter'); 
const cssSelect = require('css-select');
const ast = parse(`
  <div id="greeting">
    Hello <span class="name">Alice</span>
  </div>
`);
const nodes = cssSelect('#greeting .name', ast, {adapter: parse5adapter});
assert(nodes.length === 1);
assert(serialize(nodes[0]) === 'Alice');

Options

The adapter export from the package is an instance of an Adapter class which is configured to use the defaultTreeAdapter for parse5. If you have a parse5 generated tree which used a different adapter, you can create a new instance of the Parse5Adapter class using that parse5 tree adapter as the constructor argument. At present, there appears to be only one other tree adapter for parse5 which is the parse5-htmlparser2-tree-adapter, but this tree format is actually the default tree type for css-select pacakge, so it would probably be a silly thing to use css-select-parse5-adapter with it. If you did, it would look like the following (keeping example here in the event another parse5 tree adapter shows up on the scene for some reason):

const h2adapter = require('parse5-htmlparser2-tree-adapter');
const {Parse5Adapter} = require('css-select-parse5-adapter');
const cssSelect = require('css-select');
const adapter = new Parse5Adapter(h2adapter);
const nodes = cssSelect('#greeting .name', ast, {adapter});

FAQs

Last updated on 03 Jul 2019

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc