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


TypeScript babel-core.transform函數代碼示例

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


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

示例1: it

it('should move static apis under "Taro"', function () {
  const code = `
    import { noop } from '@tarojs/taro-h5';
    noop;
    noop();
  `

  const result = babel.transform(code, { plugins: [pluginOptions] })
  expect(result.code).toMatchSnapshot();

  const ast = result.ast as t.File
  const body = ast.program.body as [t.ImportDeclaration, t.ExpressionStatement]
  expect(t.isImportDeclaration(body[0])).toBeTruthy()
  expect(t.isExpressionStatement(body[1])).toBeTruthy()
  const defaultImport = body[0].specifiers.find(v => t.isImportDefaultSpecifier(v))
  expect(defaultImport).toBeTruthy()

  const taroName = defaultImport!.local.name
  let memberExpression = body[1].expression
  if (t.isCallExpression(body[1])) {
    memberExpression = (body[1].expression as t.CallExpression).callee
  }
  expect(memberExpression).toMatchObject(t.memberExpression(
    t.identifier(taroName),
    t.identifier('noop')
  ))
})
開發者ID:YangShaoQun,項目名稱:taro,代碼行數:27,代碼來源:index-test.ts

示例2: default

export default () => ({
  visitor: {
    CallExpression(nodePath: NodePath<CallExpression>, { opts, file }: { opts: { configFile: string }, file: any }) {
      if (isRequireCallExpression(nodePath)) {
        const arg = (nodePath.get("arguments") as any)[0];
        const filename = file.opts.filename;
        const targetFilename = arg.node.value;
        const webpackConfig = opts.configFile ? resolveWebpackConfig(opts.configFile) : opts;

        const loaders = webpackConfig.module
          ? ((webpackConfig.module as NewModule).rules || (webpackConfig.module as OldModule).loaders)
          : [];

        if (arg && arg.isStringLiteral() && isFileNeedToProcess(targetFilename, loaders)) {
          const finalTargetFileName = path.resolve(path.dirname(filename), targetFilename);

          const webpackResult = runWebpackSync(finalTargetFileName, webpackConfig);

          if (webpackResult.length === 0) {
            return;
          }
          const webpackResultAst = transform(webpackResult).ast;
          const pickedWebpackExpr = pickTheReturnOfWebpackResult(webpackResultAst);

          if (pickedWebpackExpr !== null) {
            nodePath.replaceWith(pickedWebpackExpr);
          }
        }
      }
    },
  },
});
開發者ID:morlay,項目名稱:babel-plugin-webpack-loaders-inline-exports,代碼行數:32,代碼來源:index.ts

示例3: transform

 .then((code) => {
     const result = transform(code, {
         presets: ['es2015'],
         plugins: [
             'transform-decorators-legacy',
             'transform-class-properties',
             'transform-decorators',
             'transform-object-rest-spread'
         ]
     }).code;
     return result;
 })
開發者ID:beregovoy68,項目名稱:WavesGUI,代碼行數:12,代碼來源:utils.ts

示例4: runValidation

function runValidation(source: string, expectedOutput: {}, options: Options, skipNodeCheck: boolean): void {
  let compile = options.useCS2 ? cs2Compile : cs1Compile;
  let coffeeES5 = compile(source, { bare: true }) as string;
  let decaffeinateES6 = convert(source, options).code;
  let decaffeinateES5 =
    babel.transform(decaffeinateES6, {
      presets: ['es2015'],
      plugins: ['transform-optional-chaining']
    }).code || '';

  let coffeeOutput = runCodeAndExtract(coffeeES5);
  let decaffeinateOutput = runCodeAndExtract(decaffeinateES5);
  try {
    assertDeepEqual(decaffeinateOutput, coffeeOutput, 'decaffeinate and coffee output were different.');
  } catch (err) {
    // add some additional context for debugging
    err.message = `Additional Debug:
SOURCE
${source}
********************
INPUT -> COFFEE-SCRIPT -> ES5
${coffeeES5}
********************
INPUT -> DECAFFEINATE -> ES6
${decaffeinateES6}
********************
INPUT -> DECAFFEINATE -> ES6 -> BABEL -> ES5
${decaffeinateES5}
********************
COFFEE-SCRIPT ES5 compared to DECAFFEINATE/BABEL ES5
${err.message}`;
    throw err;
  }

  // Make sure babel and V8 behave the same if we're on node >= 6.
  if (!skipNodeCheck) {
    let nodeOutput = runCodeAndExtract(decaffeinateES6);
    assertDeepEqual(decaffeinateOutput, nodeOutput, 'babel and node output were different.');
  }

  if (expectedOutput !== undefined) {
    assertDeepEqual(decaffeinateOutput, expectedOutput, 'decaffeinate and expected output were different.');
  }
}
開發者ID:alangpierce,項目名稱:decaffeinate,代碼行數:44,代碼來源:validate.ts

示例5: test

test("should transform code with absolute configFile", (t) => {
  const babelOptions = {
    plugins: [
      [
        webpackInlineLoaders,
        {
          configFile: path.join(process.cwd(), "./fixtures/webpack.config.js"),
        },
      ],
    ],
    filename: __filename,
  };

  const codeString = transform(source, babelOptions).code;

  const exports = getExportsFromCodeString(codeString);

  t.true(_.isObject(exports));
});
開發者ID:morlay,項目名稱:babel-plugin-webpack-loaders-inline-exports,代碼行數:19,代碼來源:index.spec.ts

示例6: parseCode

export function parseCode (code: string) {
  return (transform(code, {
    parserOpts: {
      sourceType: 'module',
      plugins: [
        'classProperties',
        'jsx',
        'flow',
        'flowComment',
        'trailingFunctionCommas',
        'asyncFunctions',
        'exponentiationOperator',
        'asyncGenerators',
        'objectRestSpread',
        'decorators',
        'dynamicImport'
      ]
    }
  }) as { ast: t.File }).ast
}
開發者ID:YangShaoQun,項目名稱:taro,代碼行數:20,代碼來源:utils.ts


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