- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 HTML 中有内联 javascript。每个需要动画或 Action ( slider 、扩展文本区域等)的单独组件都有自己的内联脚本,用于为该单独组件设置动画等。
我的设置方式是,每个脚本都是位置相关的:它引用自己在 DOM 中的位置,并遍历它以找到它想要操作的组件(例如“将 onclick 添加到父 div”)。这通常是一个非常糟糕的主意,原因如下:
但是,第二个问题用GZIP很容易解决,我已经解决了第一个问题和最后一个问题。
这具有引用局部性的优点:它们所需的组件和脚本保存在一个位置,而不是分散在单独的文件中。另外,我将每组脚本隔离在 (function(){})() 中,并避免污染全局命名空间,因此每个组件的每组脚本都编写一次,并且根本不与其他地方编写的脚本交互。完美的模块化
所以问题是,当我进行 Ajax DOM 插入/替换时,如何阻止 JQuery 吃掉我的脚本标签?如果它没有吃掉我的脚本,因为每个组件都完全独立于它自己的脚本,我可以简单地运行新组件的 DOM 中的每个脚本标签,就是这样;一切都会安排妥当。不再需要根据更改的组件来决定需要重新运行哪些全局脚本。
但是,由于 JQuery 似乎坚持剥离我的脚本标签并将它们移动到某个地方,所以这不再有效。我可以通过修改替换整个文档的 HTML 来完成插入,但这会导致整个屏幕在回流时闪烁(以及其他问题)。有什么想法吗?
最佳答案
我不明确了解 jQuery,但大多数库都会从 XHR 返回的内容中删除脚本元素,并打算使用innerHTML 插入这些内容。这是因为插入innerHTML 不会执行脚本(在绝大多数浏览器中)。查看 jQuery 源代码,load 方法会删除脚本元素。
因此,他们删除了脚本元素,然后插入 HTML。这可确保脚本不会执行或导致问题。
一些库有一个“执行脚本”(或类似的)标志,如果设置,意味着它们会将脚本元素内容传递给eval,但这也存在陷阱。
一种解决方案是将所有脚本片段放入单独的文件中,然后在脚本元素上使用 src 属性。如果您找不到不删除脚本的 jQuery 方法,则可以非常简单地编写自己的“get”或“load”或任何不删除脚本的函数,或者使用已编写的数千个函数之一。
如果您仅使用脚本元素,则可以简单地创建一个脚本元素,设置 src 属性并将其放入 DOM 中(这是执行 AJAX 的一种方法)。
关于javascript - 有什么方法可以阻止 JQuery 吃掉我的 <script> 标签,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6892137/
我正在审查一家海外开发公司为我们制作的一些 html。他们在外部脚本加载标签内使用注释——据我所知,这只对非常老的 javascript 不敏感的浏览器有用,他们曾经将脚本呈现为文本——是否有任何现代
这个问题在这里已经有了答案: Are HTML comments inside script tags a best practice? [closed] (10 个答案) 关闭 8 年前。 我正在
哪个更好用或者更方便: ... 或 ... 最佳答案 你真的需要类型属性吗?如果您使用的是 HTML5,则不会。否则,是的。 HTML 4.01 和 XHTML 1.0 指定了 type属性是必需的,
哪个更好用或者更方便: ... 或 ... 最佳答案 你真的需要类型属性吗?如果您使用的是 HTML5,则不会。否则,是的。 HTML 4.01 和 XHTML 1.0 指定了 type属性是必需的,
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Why don't self-closing script tags work? 我刚刚发现 HTML 中的
这个问题在这里已经有了答案: What does in XML mean? (13 个答案) 关闭 8 年前。 我不熟悉 XML 及其相关技术。 这个 CDATA 标签总是在开头,然后是一些东西
我最近遇到这个问题,我试图在我的 HTML 页面中导入多个 js 文件,如下 - 但我面临的问题是,它只加载第一个 js 文件,而其余的 js 文件没有加载。我还检查了浏览器中的网络部分,剩下的
Duplicate Why don’t self-closing script tags work? 我正在编写一个 ASP.net 页面,它在 JS 文件中有一些用于客户端身份验证的 Javascr
在这个博客中, http://www.bswebdev.com/2008/12/javascript-change-input-box-type-to-password/我发现以下代码段用于在 IE6
为什么以下行在许多浏览器(mozilla、IE)中不起作用? 为什么一定要这样设置? 最近我将我的项目从 XHTML 转换为 HTML5,我遇到了一些小但令人不安的不兼容性。 最佳答案 虽然脚本元
是什么意思?这个和其他类似的 IE 代码行在 HTML5 文档中意味着什么? 如果我必须使某些 css 功能与 IE8 或更低版本兼容,上面提到的代码行或其中提到的 html 类是否有帮助? 如果
请说明 之间有什么区别标记和 标签。 Page title 如果两者都使用,哪个最优先? 我观察到一些网站同时具有 和 tags 和 两者相同,这是预期的,请确认? 如果我们不使用 标签标题,我
这个问题已经有答案了: Why don't self-closing script elements work? (12 个回答) 已关闭 7 年前。 经过两天的 Angular 与 Webpack
我有这个代码: .roll-link { display: inline-block; overflow: hidden; vertical-align: top;
我在 the HTML 4.01 specification at w3.org 中阅读了有关 HTML 文档结构的内容.然后我偶然发现了这段代码;它看起来像某种定义。你们中的任何人都可以详细说明它的
我正在网站上工作 http://palacechemicals.co.uk/它以某种方式感染了恶意(但良性)的 JavaScript 行: 在第 251 行。脚本尝试加载的 URL 返回 404,但
尝试解析引号内的 JSON 键名称,包括转义引号。我的想法是:在引号之间取任何内容而不是,并以\ 为前缀 (?
我有个小问题。 我正在尝试使用 在 IE 中打开时有条件地设置一个唯一的 css 文件,但它不起作用。 我试着穿上 , 关于 , 关于 footer .我尝试更改我的 IE 版本,但没有任何效果。
我是 Blogger 博客用户。我曾经看到一个在 CDATA 标记内定位脚本的模板,如下所示: /**/ 虽然,我之前看到过类似的代码,如下所示: // 唯一不同的是/*
让我放心。我刚学 HTML。 根据http://www.w3.org/TR/html-markup/syntax.html#comments以及我见过的许多其他网站,例如 http://www.w3s
我是一名优秀的程序员,十分优秀!