Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >module.exports“模块未定义”

module.exports“模块未定义”
EN

Stack Overflow用户
提问于 2015-04-15 14:15:44
回答 2查看 92.8K关注 0票数 31

因此,我正在使用RequireJS和React,尝试加载一个第三方组件,该组件已随以下命令一起安装:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
npm install react-autocomplete

其结构如下:https://github.com/rackt/react-autocomplete/tree/master/lib

现在,我有一个在加载requireJS时启动的main.js文件,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
require.config({
paths: {
      "react" : "react/react",
      "jsx-transformer" : "react/JSXTransformer",
      "react-autocomplete" : "node_modules/react-autocomplete/lib/main"
    }
});

require(["react"], function(react) {
    console.log("React loaded OK.");
});

require(["jsx-transformer"], function(jsx) {
    console.log("JSX transformer loaded OK.");
});

require(['react-autocomplete'], function (Autocomplete) {
    console.log("React autocomplete component loaded OK.");
    var Combobox = Autocomplete.Combobox;
    var ComboboxOption = Autocomplete.Option;
    console.log("Autocomplete initiated OK");
 });

现在,加载一切正常,但是第三个require语句为第三方组件中的main.js文件抛出“模块未定义”,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
module.exports = {
  Combobox: require('./combobox'),
  Option: require('./option')
};

我一直在读到,这与我试图需要一个CommonJS风格的模块有关,但我不知道如何自己修复它,因为我对此还不熟悉。

有没有人有一个明确的例子来说明我如何解决这个问题?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-04-15 16:05:57

RequireJS无法按原样加载CommonJS模块。但是,为了加载它们,您可以对它们进行最小程度的修改。您必须将它们包装在define调用中,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
define(function (require, exports, module) {

  module.exports = {
    Combobox: require('./combobox'),
    Option: require('./option')
  };

});

如果您有一堆需要转换的模块,或者如果您正在使用以CommonJS模式编写的第三方库,并且希望将其作为构建过程的一部分进行转换,则可以使用r.js为您执行转换。

票数 32
EN

Stack Overflow用户

发布于 2015-04-15 15:52:00

问题是requireJS不支持CommonJS模块,只支持AMD。因此,如果第三方库不支持AMD,那么你将不得不跳过一些圈套才能让它工作。

如果可以选择,我建议使用browserifywebpack加载模块,因为大多数react社区都选择了这些工具,而且几乎所有第三方react组件都作为CommonJS模块发布在npm上。

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29652716

复制
相关文章
iOS APP添加桌面快捷方式
新接到一个需求,需要APP内的某些功能,能够把入口添加到桌面,点击桌面到入口可以直接跳转APP对应界面(类似于下面这张示例图),于是就做了一番调研。
莫空9081
2021/06/08
5.4K0
iOS APP添加桌面快捷方式
2)客户端通过OpenUrl调起Safari,再二次跳转到data url 技术实现方案是首先通过调起Safari,然后跳到一个Data URI Scheme形式下的HTML页面,而添加到主屏幕的也是这个Data URI Scheme形式下的HTML页面。 OpenUrl调起Safari的实现为: [[UIApplicationsharedApplication] openURL:[NSURL URLWithString:@"http:www.xxx.com"]]; 通过该方法即可调起Safari,让Safari访问附带的URL链接,在该功能实现中,URL链接指向一个Data URI Scheme形式下的HTML页面。如下图所示:
用户5521279
2019/06/03
7.4K3
如何向图形添加曲形文本
R语言数据分析指南
2023/08/18
2190
如何向图形添加曲形文本
如何向数组里添加元素
一般数组是不能添加元素的,因为数组在初始化时就已定好长度了,不能改变长度,我们如何做到向其中添加元素。
算法与编程之美
2023/01/03
3.5K0
kali添加桌面快捷方式
终端输入:sudo gedit /usr/share/applications/Pycharm.desktop 粘贴模板: [Desktop Entry] Type=Application Name=Pycharm GenericName=Pycharm3 Comment=Pycharm3:The Python IDE Exec=sh /opt/pycharm/bin/pycharm.sh Icon=/opt/pycharm/bin/pycharm.png Terminal=pycharm Categor
昨天50还没用完
2018/06/29
2.3K0
java如何向数组中添加元素[数组的添加]
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说java如何向数组中添加元素[数组的添加],希望能够帮助大家进步!!!
Java架构师必看
2022/04/06
7.7K0
java如何向数组里添加元素
1、一般数组是不能添加元素的,因为他们在初始化时就已定好长度了,不能改变长度。 但有个可以改变大小的数组为ArrayList,即可以定义一个ArrayList数组,然后用add(element)方法往里添加元素即可,还可add(index,element)往指定下标处添加元素;例子如下:
全栈程序员站长
2022/06/27
20.6K0
Windows中的键盘快捷方式大全
Windows有很多键盘快捷方式,使用键盘快捷方式能够大大提高使用windows的效率,同时还能提升自己的逼格,背熟几个快捷方式,操作起来行云流水犹如大神一般!
用户7657330
2020/08/14
5.7K0
如何向已有的项目中添加C/C++代码?
  我们需要在src/main下面建立一个cpp目录,然后在其中写一个CMakeLists.txt文件和一个cpp文件,直接给出代码:
故乡的樱花开了
2023/10/22
2930
给App的应用页面注册快捷方式
元数据不单单能传递简单的字符串参数,还能传送更复杂的资源数据,从Android7.1开始新增的快捷方式便用到了这点,譬如在手机上桌面长按支付宝图标,会弹出如下图所示的菜单。
aqi00
2020/05/12
9680
Python 中如何向列表或数组添加元素
然而,与其它编程语言不同,数组在 Python 中不是一个内置的数据结构。Python 使用列表取代传统的数组。
Python学习者
2023/09/11
3600
向邮件添加附件
可以将附件添加到电子邮件或消息部分(具体地说,是添加到%Net.MailMessagePart或%Net.MailMessage的实例)。要执行此操作,请使用以下方法:
用户7741497
2022/06/09
2.1K0
如何从Windows切换到Linux
微软已经马上准备在2020年1月份终止对Windows 7的支持,这意味着您将不再获得bug修复或安全更新。如果您是Windows 7的最终支持者之一,并且不想陷入一个不安全的系统,则可以选择:升级到Windows 10或完全切换到其他版本。
用户6543014
2020/02/10
3.9K0
如何添加windows定时计划任务?
“ 我们常常使用linux添加定时任务,windows也可以吗?答案是肯定的——编程三分钟”
机智的程序员小熊
2019/12/11
1.7K0
Windows如何添加TrustedInstaller权限
权限添加,一同加的Administrator、Users、TrustedInstaller(英文分号隔开)然后点检索名称,Administrator和Users都能找到,唯独TrustedInstaller不行
Windows技术交流
2020/04/08
4.1K0
如何使用 Bootstrap class 向按钮添加下拉菜单
如何使用 Bootstrap class 向按钮添加下拉菜单。如需向按钮添加下拉菜单,只需要简单地在一个 .btn-group 容器中放置按钮和下拉菜单即可。您也可以使用 <span class="caret"></span> 来指示按钮作为下拉菜单。
好派笔记
2021/09/18
5.6K0
短视频app源码开发,如何添加启动界面
打开短视频app源码时,一般都会有一个启动界面,启动界面除了会展示APP的logo外,大多数都会将广告直接放到上面,起到引流盈利的目的。
云豹科技程序员
2021/06/21
6700
点击加载更多

相似问题

如何向windows快捷方式添加命令参数

124

如何向App添加社交功能?

43

Android:如何向App添加阴影

13

如何从azure向windows mobile cordova app发送推送通知

112

向APp添加项

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文