當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript parse5.parseFragment函數代碼示例

本文整理匯總了TypeScript中parse5.parseFragment函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript parseFragment函數的具體用法?TypeScript parseFragment怎麽用?TypeScript parseFragment使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了parseFragment函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: test

 test('prepend', () => {
   const orderedList =
       parse5.parseFragment(`<ol><li>1<li>2<li>3<li>4<li>5</ol>`);
   const ol = orderedList.childNodes![0]!;
   const li3 = ol.childNodes![2]!;
   ast.prepend(ol, li3);
   assert.equal(
       parse5.serialize(ol.parentNode!),
       parse5.serialize(
           parse5.parseFragment(`<ol><li>3<li>1<li>2<li>4<li>5</ol>`)));
 });
開發者ID:MehdiRaash,項目名稱:tools,代碼行數:11,代碼來源:parse5-utils_test.ts

示例2: addCustomElementsEs5Adapter

export function addCustomElementsEs5Adapter(html: string): string {
  // Only modify this file if we find a web components polyfill. This is a
  // heuristic to identify the entry point HTML file. Ultimately we should
  // explicitly transform only the entry point by having the project config.
  if (!webcomponentsLoaderRegex.test(html)) {
    return html;
  }
  const parsed = parse5.parse(html, {locationInfo: true});
  const script = dom5.query(parsed, webcomponentsLoaderMatcher);
  if (!script) {
    return html;
  }

  // Collect important dom references & create fragments for injection.
  const loaderScriptUrl = dom5.getAttribute(script, 'src')!;
  const adapterScriptUrl =
      url.resolve(loaderScriptUrl, 'custom-elements-es5-adapter.js');
  const es5AdapterFragment = parse5.parseFragment(`
    <script>if (!window.customElements) { document.write('<!--'); }</script>
    <script type="text/javascript" src="${adapterScriptUrl}"></script>
    <!--! do not remove -->
`);

  dom5.insertBefore(script.parentNode!, script, es5AdapterFragment);
  return parse5.serialize(parsed);
}
開發者ID:Polymer,項目名稱:polymer-build,代碼行數:26,代碼來源:custom-elements-es5-adapter.ts

示例3: processFile

  private async processFile(file: File): Promise<File> {
    if (file.path !== this.entrypoint) {
      return file;
    }
    const contents = await getFileContents(file);
    const document = parse5.parse(contents);

    const babelHelpersFragment =
        parse5.parseFragment('\n\n<script></script>\n\n');
    dom5.setTextContent(
        babelHelpersFragment.childNodes![1]!,
        await fs.readFile(
            path.join(__dirname, 'babel-helpers.min.js'), 'utf-8'));

    const firstScriptOrImport = dom5.nodeWalk(document, scriptOrImport);
    if (firstScriptOrImport) {
      dom5.insertBefore(
          firstScriptOrImport.parentNode!,
          firstScriptOrImport,
          babelHelpersFragment);
    } else {
      const head =
          dom5.query(document, dom5.predicates.hasTagName('head')) || document;
      dom5.append(head, babelHelpersFragment);
    }

    const newFile = file.clone();
    newFile.contents = new Buffer(parse5.serialize(document), 'utf-8');
    return newFile;
  }
開發者ID:chrisekelley,項目名稱:polymer-build,代碼行數:30,代碼來源:inject-babel-helpers.ts

示例4: test

 test('accepts document fragments', () => {
   const fragment = parse5.parseFragment('<span></span>foo');
   dom5.insertAfter(dom, span, fragment);
   assert.equal(
       parse5.serialize(dom),
       '<div></div><span></span><span></span>footext');
   assert.equal(fragment.childNodes!.length, 0);
 });
開發者ID:Polymer,項目名稱:tools,代碼行數:8,代碼來源:dom5_test.ts

示例5: test

 test('inSourceOrder', () => {
   const html = parse5.parseFragment(`
         <span>oh</span><span>hi</span>
         <span>good</span>
       <span>bye</span>
     `, {locationInfo: true});
   const spans = dom5.queryAll(html, dom5.predicates.hasTagName('span'));
   assert.isTrue(ast.inSourceOrder(spans[0], spans[1]), 'oh -> hi');
   assert.isTrue(ast.inSourceOrder(spans[0], spans[3]), 'oh -> bye');
   assert.isTrue(ast.inSourceOrder(spans[2], spans[3]), 'good -> bye');
   assert.isFalse(ast.inSourceOrder(spans[3], spans[1]), 'bye <- hi');
   assert.isFalse(ast.inSourceOrder(spans[1], spans[0]), 'hi <- oh');
 });
開發者ID:Polymer,項目名稱:vulcanize,代碼行數:13,代碼來源:parse5-utils_test.ts

示例6:

  const injectScript = (js: string) => {
    const fragment = parse5.parseFragment('<script></script>\n');
    dom5.setTextContent(fragment.childNodes![0], js);

    const firstJsScriptOrHtmlImport =
        dom5.query(document, isJsScriptOrHtmlImport);
    if (firstJsScriptOrHtmlImport) {
      dom5.insertBefore(
          firstJsScriptOrHtmlImport.parentNode!,
          firstJsScriptOrHtmlImport,
          fragment);

    } else {
      const headOrDocument =
          dom5.query(document, dom5.predicates.hasTagName('head')) || document;
      dom5.append(headOrDocument, fragment);
    }
  };
開發者ID:MehdiRaash,項目名稱:tools,代碼行數:18,代碼來源:html-transform.ts


注:本文中的parse5.parseFragment函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。