如何在webpack上使用babel和typescript公开jquery插件

时间:2017-10-20 07:47:53

标签: jquery typescript webpack babel

我一直在努力让以下代码无法正常运行。

第1步图书馆建设

我使用typescript构建了很多es6代码。我编译它们以使用babel和typescript获取js lib。到目前为止一切都有效。在我的lib的顶部,我有一个包装器,它允许我使用jquery扩展快速访问lib主组件:

require('jquery');

$.fn.extend({
  saidashboard : function (options: SAIDashboardConfig) {
    let builtEntry: SAIDashboardView;
    /* ... some code ... */
    return builtEntry;
  }
});

第2步测试

我有一个应该测试库的测试文件。在test-empty.js文件中,我加载一些json描述符并尝试用它初始化我的对象

'use strict';

var chai = require('chai');
var $ = require("jquery");
var fs = require('fs');
require('../dist/sai-dashboard');

chai.should();

var newDash;

before( function(done) {
  try{
    fs.readFile('./tests/resources/descriptors/empty-dashboard.json', 'utf8', function (err,data) {
        if (err) {
            done(new Error(err));
        } else {
            var newDashEl = $('<div></div>').addClass('dashboard-test-container');
            newDash = newDashEl.saidashboard(JSON.parse(data));
            done();
        }
    });
  }catch(e){
    done(e);
  }
});

问题

我无法停止收到以下错误

Uncaught TypeError: newDashEl.saidashboard is not a function

如果我的$ .fn.extend在不同的jquery实例上调用它而不是我使用的那个。

我使用以下方式启动测试:

mocha-webpack --require setup-test.js --require source-map-support/register --webpack-config webpack.config-test.js tests/test-empty.js

这是setup.js文件:

const JSDOM = require('jsdom').JSDOM;

const { document } = (new JSDOM('')).window;
global.document = document;
global.window = document.defaultView;
window.console = global.console;

Object.keys(document.defaultView).forEach((property) => {
  if (typeof global[property] === 'undefined') {
    global[property] = document.defaultView[property];
  }
});

global.navigator = {
  userAgent: 'node.js'
};

和webpack.config-test.js

var nodeExternals = require('webpack-node-externals');

module.exports = {
  output: {
  // sourcemap support for IntelliJ/Webstorm 
    devtoolModuleFilenameTemplate: '[absolute-resource-path]',
    devtoolFallbackModuleFilenameTemplate: '[absolute-resource-path]?[hash]'
  },
  target: 'node', // in order to ignore built-in modules like path, fs, etc. 
  externals: [nodeExternals()], // in order to ignore all modules in node_modules folder 
  devtool: "cheap-module-source-map" // faster than 'source-map' 
};

有什么想法吗?

由于

1 个答案:

答案 0 :(得分:0)

所以我最终与一些严重依赖于某些jQuery插件的项目有关,就是使用expose-loader和script-loader。以下内容确保我可以访问jQuery,并且可以全局访问它。

// Example of my app.includes.js
require('expose-loader?jQuery!jquery');
require('expose-loader?$!jquery');

// Then require your plugins using the script-loader to execute them
// so they are part of the global jQuery object.
require('script-loader!your/jQuery/plugin/here')

然后我必须将app.includes.js放入我的webpack条目app.js

// app.js
require('./app.inlcudes');

改变对导入的要求不会有任何损害,您可以在 webpack.config.js 中包含 expose-loader 。规则也是如此。我有一些非常具体的原因可以解释为什么我的内联使用符合要求。