js如何兼容多种模块规范

发布于 2022-09-11 23:26:44 字数 726 浏览 19 评论 0

要写一个第三方系统对接插件
vue、react、jquery等等
怎样才能一个js兼容不同的引入方式
require
import
script src
目前代码是这样的

;(function (_params) {
  "use strict"
  var open = function(){
    var xhr = new XMLHttpRequest();
    xhr.open("POST", url, true);
    ...
  }
  
  if (typeof module !== 'undefined' && typeof exports ==='object') { 
    module.exports = open;  
  } else if (typeof define === 'function' && define.amd) { 
    define(function() {    return open;  });   
  } else {
    window.openPage = open;    
  }
})()

然后现在在vue项目中试发现依旧会执行window.openPage = open,没办法使用import、require
求助!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

很快妥协 2022-09-18 23:26:44

建议使用 Webpack 来做这种事儿。

如果真要徒手写的话,可以这样:

(function moduleDefinition(root, factory) {
    const $ = 'myModule'; // 自定义模块名

    if ('object' === typeof wx && 'object' === typeof module && !!wx.login) {
        module.exports[$] = factory(); // 兼容 Wechat Mini-Program
    } else if ('object' === typeof my && 'object' === typeof module && !!my.login) {
        module.exports[$] = factory(); // 兼容 Alipay Mini-Program
    } else if ('object' === typeof swan && 'object' === typeof module && !!swan.login) {
        module.exports[$] = factory(); // 兼容 Baidu Smart-Program
    } else if ('object' === typeof tt && 'object' === typeof module && !!tt.login) {
        module.exports[$] = factory(); // 兼容 Toutiao Mini-App
    } else if ('object' === typeof exports && 'object' === typeof module) {
        module.exports[$] = factory(); // 兼容 CommonJS
    } else if ('function' === typeof define && (define.amd || define.cmd)) {
        define(factory); // 兼容 AMD/CMD
    } else if ('object' === typeof exports) {
        exports[$] = factory();
    } else if (root) {
        root[$] = factory();
    }
})(this, (() => {
    'use strict';
    
    return function() {
        console.log('hello world');
    }; // 要导出的模块示例
}));

使用时:

// 使用 import
import { myModule } from 'sample.js';
myModule();

// 使用 require
const sample = require('sample.js');
sample.myModule();

// 浏览器环境 src 直接引用
<script src="sample.js"></script>
<script>window.myModule();</script>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文