- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个合作伙伴正在尝试嵌入的 jQuery 小部件。我们遇到的问题是合作伙伴正在使用 requireJS 及其影响小部件。
该小部件位于匿名函数中,并且需要在其中使用 jquery-ui。调试后我们发现 jQuery UI 在 noConflict 调用后被删除。这是来自小部件的代码。
(function () {
// Localize jQuery variable
var jQueryWidget;
/******** Load jQuery if not present *********/
if (window.jQuery === undefined || window.jQuery.fn.jquery !== '3.2.1') {
var script_tag = document.createElement('script');
script_tag.setAttribute("type", "text/javascript");
script_tag.setAttribute("src", "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js");
script_tag.onload = scriptLoadHandler;
script_tag.onreadystatechange = function () { // Same thing but for IE
if (this.readyState == 'complete' || this.readyState == 'loaded') {
scriptLoadHandler();
}
};
(document.getElementsByTagName("head")[0] || document.documentElement).appendChild(script_tag);
} else {
loadJQueryUi();
}
function scriptLoadHandler() {
loadJQueryUi();
}
function loadJQueryUi() {
/******* Load UI *******/
jQuery.getScript('https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js', function () {
jQueryWidget = jQuery.noConflict(true);
setHandlers(jQueryWidget);
});
/******* Load UI CSS *******/
var css_link = jQuery("<link>", {
rel: "stylesheet",
type: "text/css",
href: "https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/base/jquery-ui.css"
});
css_link.appendTo('head');
}
function setHandlers($) {
$(document).on('focus', '#start-date, #end-date', function(){
$('#start-date').datepicker({
dateFormat: "M dd, yy",
minDate: 'D',
numberOfMonths: 1,
});
$('#end-date').datepicker({
dateFormat: "M dd, yy",
minDate:'+1D',
numberOfMonths:1,
});
}
})();
最佳答案
问题是你试图做的事情是不安全的。有两个因素综合起来对您不利:
define
获取其依赖项,并且不会将任何内容泄漏到全局空间中。不幸的是,jQuery 确实泄漏了 $
和 jQuery
进入全局空间。 $
和
jQuery
指的是。考虑你的代码:
jQuery.getScript('https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js', function () {
jQueryWidget = jQuery.noConflict(true);
setHandlers(jQueryWidget);
});
jQuery
指您要求加载的版本或合作伙伴代码想要加载的版本。唯一
.getScript
保证在脚本加载后将调用回调,但它确实
不是 防止其他脚本在
.getScript
的脚本之间加载加载和调用回调的时间。浏览器可以完全免费加载您提供给
.getScript
的脚本,加载一些通过 RequireJS 请求的其他脚本,然后调用您的回调。
context
RequireJS 的配置选项不是修复。如果没有试图通过全局
$
访问 jQuery 的脚本,这将是一个修复。或
jQuery
,但是有很多 jQuery 插件可以做到这一点。您无法确保合作伙伴代码不使用它们。
script
加载 jQuery 和 jQuery UI。元素。然而,他们都检查是否
define
可用,如果可用,他们将调用
define
.这可能会导致各种问题,具体取决于一切发生的顺序,但一个可能的问题是,如果 RequireJS 在您的小部件加载之前存在,jQuery UI 将从
script
调用定义。元素,这将产生
mismatched anonymous define
error . (jQuery 有一个不同的问题,它更复杂,不值得深入研究。)
define
应该强制在你的包中是假的,以便任何测试
define
存在的代码未触发。 (请参阅
import-loader
,它可以用于此目的。)如果您将代码作为单个包加载,那么它可以以同步方式初始化自己,并且您可以确定
$
和
jQuery
请参阅您的包中包含的 jQuery。
npm install webpack jquery jquery-ui imports-loader lite-server
./node_modules/.bin/webpack
./node_modules/.bin/lite-server
noConflict
当你用 Webpack 包装你的代码时,因为当它被 Webpack 包装时,jQuery 检测到一个带有 DOM 的 CommonJS 环境并打开一个
noGlobal
内部标志,防止泄漏到全局空间。
webpack.conf.js
:
const webpack = require('webpack');
module.exports = {
entry: {
main: "./widget.js",
"main.min": "./widget.js",
},
module: {
rules: [{
test: /widget\.js$/,
loader: "imports-loader?define=>false",
}],
},
// Check the options for this and use what suits you best.
devtool: "source-map",
output: {
path: __dirname + "/build",
filename: "[name].js",
sourceMapFilename: "[name].map.js",
},
plugins: [
new webpack.optimize.UglifyJsPlugin({
sourceMap: true,
include: /\.min\.js$/,
}),
],
};
widget.js
:
var $ = require("jquery");
require("jquery-ui/ui/widgets/datepicker");
var css_link = $("<link>", {
rel: "stylesheet",
type: "text/css",
href: "https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/base/jquery-ui.css"
});
css_link.appendTo("head");
$(document).ready(function() {
console.log("jQuery compare (we want this false)", $ === window.$);
console.log("jQuery version in widget", $.fn.jquery);
console.log("jQuery UI version in widget", $.ui.version);
$("#end-date").datepicker();
});
index.html
:
<!DOCTYPE html>
<html>
<head>
<script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.3.5/require.js"></script>
<script>
require.config({
paths: {
jquery: "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.0/jquery.min",
"jquery-ui": "https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.0/jquery-ui"
}
});
require(["jquery", "jquery-ui"], function(myJQuery) {
console.log("jQuery compare (we want this true)", myJQuery === $);
console.log("jQuery version main", $.fn.jquery);
console.log("jQuery ui version main", $.ui.version);
})
</script>
</head>
<body>
<input id="end-date">
<script src="build/main.min.js"></script>
<!-- The following also works: -->
<!--
<script>
require(["build/main.min.js"]);
</script>
-->
</body>
</html>
关于javascript - RequireJS 影响嵌入式 jquery-ui 小部件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46810789/
这是一个非常笼统的问题,我希望我能答对。 我正在研究 SSL/TLS 重新协商并已阅读了一些内容。这是我从阅读中了解到的内容: 从 SSL/TLS 重新协商的角度来看,客户端分为两个主要组,打补丁的和
第一个屏幕是艺术的细节。当我向上滚动时,标题将是 alpha。我点击另一个“艺术”到另一个细节 UI,然后按回到 Previous UI。之前的UI标题是黑色的,怎么变透明了。 布局:
想知道 mv 对基表的影响。它会减慢基表的速度吗?它什么时候开始写入 mv,就像同时写入基表和 mv 一样? 如果我有 local_quorum 的 CL 且 RF=3,客户端是否必须等到写入 mv
似乎在任何地方都找不到太多关于此问题的帮助,所以我想我会在这里尝试。 我正在尝试制作一个简单的 for 循环,当我将鼠标悬停在 html 卡上时,它会隐藏卡中的一些文本。该卡有一个简单的名字和姓氏,我
我有一个程序每帧运行 tick() 方法。我希望一个对象根据设定的重力常数下落,因此我创建了一个 Ball 对象,该对象会将其位置更新为前一帧的位置减去 y 速度。每个刻度 y 速度都会减少重力常数。
我的 KeyHandler 在这里: private void KeyHandler(java.awt.event.KeyEvent evt) {
我有一个方法,其中使用了很多其他类,包括链接列表、队列和堆栈。在我的方法中,我有一个 for 循环,我想在其中弹出堆栈(方便地命名为 s)并将队列(方便地命名为 q)出队到 s1 和 q1。由于某种原
我有一个 JTree 节点数组和另一个自定义对象的相应数组。 我想要什么:当选择 JTree 的节点时,相应对象(其数组中索引与节点数组中所选节点索引相同的对象)的字段填充 JLabels。 我被困在
我知道浏览器完成了处理客户端脚本(Javascript、JQuery 等)的所有工作,但想知道在性能方面是否还有其他重要因素(网络速度、客户端计算机速度、服务器环境) 如果它完全依赖于浏览器(类型和版
我有一个 Android 服务在后台运行,它将使用以下代码: while(true) { ServerSocket server = new ServerSocket(1234); Socke
对JQM有以下疑惑: 1.如果我们在单独的 html 文件中使用重复的 id,对 jquery mobile 有什么影响。 假设我们在单独的 html 文件中有重复的 id,但如果我们不使用该 id
我正在尝试更新两个(inventory、sold)MySQL 表的表库存。 假设我们正在处理的 sku 是 BT888-16 UPDATE inventory JOIN sold ON invento
我使用这种方法来更改我的表格单元格值, 它在 jtable 上改变但在文本文件上没有改变! public class user_AllBooks extends AbstractTableModel
我想在向表中插入数据时创建一个 MYSQL 存储过程,数据也会被插入到其他服务器表中。 我知道这在 ORACLE 数据库中是可能的,但我不知道它是否适用于 MYSQL。 有什么办法吗? 最佳答案 是的
我在 css 方面非常糟糕,只能靠 SO 答案来解决 - 但是我找不到针对这个特定问题的任何解释。 我有一个表单,其中包含一个 textarea 和一个 button(input/submit),仅此
我在一个元素上有动画,但它的移动也会影响 sibling 。如何在不影响兄弟元素的情况下仅在元素上使用动画? 问题示例: function animateSearch() { $('.glyph
我试图在我的 ViewController 中的 UIView 的所有四个边上建立一个阴影 — 在我通过 Xcode 向 UIView 添加约束之前,它工作得很好。我怎样才能使 UIView 的阴影显
自从我使用 JavaScript 以来已经有一段时间了 - 在获得证书之后我开始学习 Perl 并从那时起就一直使用它。我只是想重新开始使用 JS,我已经写了这个,我想说的是,这是一个简单的小脚本,可
我正在处理一个 HTML 元素,我添加了一个复选框,选中后会高亮显示所有文本输入字段。唯一的问题是一些输入字段在表格内,出于某种原因我无法用我的代码影响它们。任何帮助将不胜感激。 相关代码: HTML
我为 String 类创建了一个小扩展,以便方便地从中删除字符。这是它的样子: mutating func drop(characters chars: [String]) { for c i
我是一名优秀的程序员,十分优秀!