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


TypeScript webpack.default方法代碼示例

本文整理匯總了TypeScript中webpack.default方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript webpack.default方法的具體用法?TypeScript webpack.default怎麽用?TypeScript webpack.default使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在webpack的用法示例。


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

示例1: default

export default (fixture, options = {}): Promise<webpack.Stats> => {
  const compiler: webpack.Compiler = webpack({
    context: __dirname,
    entry: `../${fixture}`,
    output: {
      path: path.resolve(__dirname),
      filename: 'bundle.js',
    },
    module: {
      rules: [{
        test: /\.graphql$/,
        use: [
          {
            loader: path.resolve(__dirname, 'fakeLoader.ts')
          },
          {
            loader: path.resolve(__dirname, '../../index.ts'),
            options
          }
        ]
      }]
    }
  });

  compiler.outputFileSystem = new MemoryFileSystem() as any;

  return new Promise((resolve, reject) => {
    compiler.run((err, stats) => {
      if (err || stats.hasErrors()) {
        return reject(err || new Error(`Webpack Error: ${stats.toJson().errors.join(', ')}`));
      }
      resolve(stats);
    });
  });
};
開發者ID:avantcredit,項目名稱:gql2ts,代碼行數:35,代碼來源:compiler.ts

示例2: parseInt

    .action((args, cb) => {
      let port = helper.isInt(args.options.port) ? parseInt(args.options.port, 10) : 4200;
      let config = getDevConfig();
      let cssConfig = getCSSConfig();
      
      config.entry.app.unshift(`webpack-dev-server/client?http://localhost:${port}/`);
      
      let compiler = webpack([config, cssConfig]);      

      server = new webserv(compiler, {
        contentBase: './src',
        quiet: true,
        historyApiFallback: true,
        watchOptions: {
          aggregateTimeout: 1000,
          poll: 100
        }
      });

      server.listen(port, () => {
        s.status = true;
        s.port = port;
        s.ui.log(chalk.yellow(`Server running at port ${port}`));
        open(`http://localhost:${port}`);
      });

      s.server = server;

      cb();
    })
開發者ID:jkuri,項目名稱:ng2-cli,代碼行數:30,代碼來源:start.ts

示例3: Promise

  run: function(runTaskOptions: ServeTaskOptions) {

    var project = this.cliProject;

    rimraf.sync(path.resolve(project.root, runTaskOptions.outputPath));
    var config = new NgCliWebpackConfig(project, runTaskOptions.target, runTaskOptions.environment).config;
    const webpackCompiler = webpack(config);

    const ProgressPlugin  = require('webpack/lib/ProgressPlugin');

    webpackCompiler.apply(new ProgressPlugin({
      profile: true
    }));

    return new Promise((resolve, reject) => {
      webpackCompiler.run((err, stats) => {
        // Don't keep cache
        // TODO: Make conditional if using --watch
        webpackCompiler.purgeInputFileSystem();

        if(err) {
          lastHash = null;
          console.error(err.stack || err);
          if(err.details) console.error(err.details);
            reject(err.details);
        }

        if(stats.hash !== lastHash) {
          lastHash = stats.hash;
          process.stdout.write(stats.toString(webpackOutputOptions) + "\n");
        }
        resolve();
      });
    });
  }
開發者ID:Alber70g,項目名稱:angular-cli,代碼行數:35,代碼來源:build-webpack.ts

示例4: runWebpack

function runWebpack(done) {
  // https://webpack.github.io/docs/webpack-dev-server.html
  let opts = {
    host: 'localhost',
    publicPath: config.output.publicPath,
    filename: config.output.filename,
    hot: project.platform.hmr || CLIOptions.hasFlag('hmr'),
    port: project.platform.port,
    contentBase: config.output.path,
    historyApiFallback: true,
    open: project.platform.open,
    stats: {
      colors: require('supports-color')
    },
    https: config.devServer.https
  } as any;

  if (project.platform.hmr || CLIOptions.hasFlag('hmr')) {
    config.plugins.push(new webpack.HotModuleReplacementPlugin());
    config.entry.app.unshift(`webpack-dev-server/client?http://${opts.host}:${opts.port}/`, 'webpack/hot/dev-server');
  }

  const compiler = webpack(config);
  let server = new Server(compiler, opts);

  // tslint:disable-next-line:only-arrow-functions
  server.listen(opts.port, opts.host, function(err) {
    if (err) { throw err; }

    reportWebpackReadiness(opts);
    done();
  });
}
開發者ID:jbockle,項目名稱:aurelia-json-schema-form,代碼行數:33,代碼來源:run.ts

示例5: Observable

    return new Observable(obs => {
      const devServerConfig = devServerCfg || webpackConfig.devServer || {};
      devServerConfig.host = devServerConfig.host || 'localhost';
      devServerConfig.port = devServerConfig.port || 8080;

      if (devServerConfig.stats) {
        webpackConfig.stats = devServerConfig.stats;
      }
      // Disable stats reporting by the devserver, we have our own logger.
      devServerConfig.stats = false;

      const webpackCompiler = webpack(webpackConfig);
      const server = new WebpackDevServer(webpackCompiler, devServerConfig);

      webpackCompiler.hooks.done.tap('build-webpack', (stats) => {
        // Log stats.
        loggingCb(stats, webpackConfig, this.context.logger);

        obs.next({ success: !stats.hasErrors() });
      });

      server.listen(
        devServerConfig.port,
        devServerConfig.host,
        (err) => {
          if (err) {
            obs.error(err);
          }
        },
      );

      // Teardown logic. Close the server when unsubscribed from.
      return () => server.close();
    });
開發者ID:fmalcher,項目名稱:angular-cli,代碼行數:34,代碼來源:index.ts

示例6: it

 it("apply", (done) => {
     let isCalled = false;
     const fileChanger = new FileChanger({
         move: [{
             from: path.resolve(rootFolder, './assets', 'index.html'),
             to: './index.html',
             parameters: {
                 'app\\.min\\.js': 'app.0.[renderedHash:0].min.js'
             },
             before: (stats, move) => {
                 console.log("before moving");
             },
             after: (stats, move) => {
                 console.log("after moved")
             }
         }],
         complete: (stats) => {
             if (isCalled) {
                 done();
             }
             isCalled = true;
         }
     });
     const webpackConfig: any = new WebpackConfig();
     webpackConfig.plugins.push(fileChanger);
     webpack(webpackConfig, function () {
         rimraf(outFolder, fs, () => {
             if (isCalled) {
                 done();
             }
             isCalled = true;
         });
     });
 });
開發者ID:kbukum,項目名稱:webpack-file-changer,代碼行數:34,代碼來源:FileChanger.spec.ts

示例7: Promise

  return new Promise((resolve, reject) => {
    const compiler = webpack({
      ...webpackConfig,
      entry: filename,
      output: {
        ...webpackConfig.output,
        libraryTarget: "commonjs2",
        path: destDir,
        filename: name,
      },
    });

    compiler.outputFileSystem = fs;

    compiler.run((err) => {
      if (err) {
        reject(err);
      }

      const resultFilename = path.resolve(destDir, name);

      if (fs.existsSync(resultFilename)) {
        resolve(String(fs.readFileSync(resultFilename)));
      } else {
        resolve("");
      }
    });
  });
開發者ID:morlay,項目名稱:simplify-svg,代碼行數:28,代碼來源:index.spec.ts

示例8: webpack

const createCompiler = (webpackConf): webpack.Compiler => {
  const compiler = webpack(webpackConf)
  compiler.hooks.invalid.tap('taroInvalid', filepath => {
    // console.log(chalk.grey(`[${formatTime()}]Modified: ${filepath}`))
    getServeSpinner().text = 'Compiling...'
    getServeSpinner().render()
  })
  compiler.hooks.done.tap('taroDone', stats => {
    const { errors, warnings } = formatWebpackMessage(stats.toJson(true))
    const isSuccess = !errors.length && !warnings.length
    if (isSuccess) {
      getServeSpinner().stopAndPersist({
        symbol: '✅ ',
        text: chalk.green('Compile successfully!\n')
      })
    }
    if (errors.length) {
      errors.splice(1)
      getServeSpinner().stopAndPersist({
        symbol: '🙅  ',
        text: chalk.red('Compile failed!\n')
      })
      console.log(errors.join('\n\n') + '\n')
    }
    if (warnings.length) {
      warnings.splice(1)
      getServeSpinner().stopAndPersist({
        symbol: '⚠️  ',
        text: chalk.yellow('Compile completes with warnings.\n')
      })
      console.log(warnings.join('\n\n') + '\n')
    }
  })
  return compiler
}
開發者ID:ApolloRobot,項目名稱:taro,代碼行數:35,代碼來源:index.ts

示例9: Webpack

const addDevMiddlewares = (app: Express.Application, webpackConfig: Webpack.Configuration) => {
  const compiler = Webpack(webpackConfig);
  const middleware = WebpackDevMiddleware(compiler, {
    noInfo: true,
    publicPath: webpackConfig.output.publicPath,
    silent: true,
    stats: 'errors-only',
  });

  app.use(middleware);
  app.use(WebpackHotMiddleware(compiler));

  // Since webpackDevMiddleware uses memory-fs internally to store build
  // artifacts, we use it instead
  const fs = middleware.fileSystem;

  if (Pkg.dllPlugin) {
    app.get(/\.dll\.js$/, (req, res) => {
      const filename = req.path.replace(/^\//, '');
      res.sendFile(Path.join(process.cwd(), Pkg.dllPlugin.path, filename));
    });
  }

  app.get('*', (req, res) => {
    fs.readFile(Path.join(compiler.options.output.path, 'index.html'), (err, file) => {
      if (err) {
        res.sendStatus(404);
      } else {
        res.send(file.toString());
      }
    });
  });
};
開發者ID:StrikeForceZero,項目名稱:react-boilerplate,代碼行數:33,代碼來源:frontendMiddleware.ts

示例10: express

> = (context: interfaces.Context) => (app?: express.Application) => {
  if (!app) {
    app = express();
  }
  context.container.get<interfaces.Factory<express.Application>>(
    registry.ExpressConfig
  )(app);
  useContainer(context.container);
  useExpressServer(app, {
    routePrefix: '/api',
    controllers: [
      CardSetController
    ],
    development: true,
    validation: { validationError: { target: false, value: false } }
  });
  app.use(historyApiFallback());
  app.use(
    webpackMiddleware(webpack(webpackDevConfig), {
      publicPath: '/',
      index: 'index.html',
      stats: {
        colors: true
      }
    })
  );
  context.container.get<interfaces.Factory<express.Application>>(
    registry.ExpressErrorConfig
  )(app);

  return app;
};
開發者ID:patrickhousley,項目名稱:xyzzy-mean,代碼行數:32,代碼來源:express-dev.ts


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