- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我是一个 python/数据的人,在一点网络上四处闲逛,对 JS 和 dom 等等一无所知。所以发生了一些非常奇怪的事情,即使我找到了解决方案,我也在努力理解其中的原因。
场景:常见问题
之前有大约一百万个 SO 问题是这样的:“我有一些工作的 jQuery/JS 可以操纵一些 HTML。然后我没有对相关的 HTML 进行硬编码,而是以编程方式在其他地方创建它并将其拖入AJAX。突然间一切都崩溃了。”
总是,答案是这样的:“你不能那样做。将你的代码连接到父子链的更高层,事件委托(delegate)是一个神奇的东西,它会拯救你。”
所以这发生在我身上,我花了一个小时左右的时间阅读以前的 SO 并了解事件委托(delegate),事实上,它救了我,我的代码也能正常工作。
但我不明白为什么它一开始就坏了。所以我希望有人能向我解释基本理论,这样我就会对整个 dom 位有更深入的了解。
一些损坏的代码
$(document).ready(function(){
$("#autopubs").load("pubslist.html");
// Obviously, the stuff in pubslist.html is what the next line was
// supposed to work on
$('.collapse').on('show.bs.collapse', function () {
$('.collapse.in').collapse('hide');
});
});
这个解决方案可能并不令人意外。将 autopubs 包裹在一个外部 div 中,并将折叠的东西卡在上面。完成,工作,非常不满意。
但我仍然不明白为什么这是必要的。这是我认为损坏的代码应该做什么的心智模型。
除了 4 从未发生过,因为第二行代码显然看不到第一行添加的所有内容。
直觉上,这有两个似是而非的原因:
第二行在第一行完成获取文件之前执行。如果这是真的,那么我学到了一些关于 javascript(或 jquery、ajax 或其他东西)的重要知识:行并不总是执行按顺序,或者至少不要总是在下一个开始之前完成。
第一行实际上根本没有改变任何状态。 DOM 不是状态。它是别的东西,东西......甚至可能是不可变的?第一行完全修补了其他东西,第二行无法触及的东西,因为它试图修补 DOM。
老实说,这两种可能性对我来说都有些奇怪。但显然有一些我根本不理解的事情发生在引擎盖下。有人可以帮助我吗?
最佳答案
JavaScript 大量使用异步行为。行在同一函数内按顺序执行,但这并不意味着它们“完成”了它们的操作。
如果您查看load
(http://api.jquery.com/load/) 的文档,您会发现它采用可选的complete
参数。那是一个回调。这是一个将在操作完成时运行的函数。调用 load
本身只会让加载开始,有点“在后台”。
所以你可以这样做:
$(document).ready(function(){
$("#autopubs").load("pubslist.html", function() {
$('.collapse').on('show.bs.collapse', function () {
$('.collapse.in').collapse('hide');
});
});
});
加载回调在加载完成后运行。
为什么您最初的 hack-solution 确实有效?它将事件处理程序附加到现有的外部 div,加载的 HTML 稍后在加载时放入其中。
关于javascript - js 新手试图通过 ajax 混淆来理解 dom(概念),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33275228/
我是 Xcode 4.4 和 AppleScriptObjC 世界的新手。我正在尝试扩展和试验 Sanderson 和 Rosenthal 所著的“学习 AppleScript”一书中关于 Apple
我完全迷失在 shell 编程中,主要是因为我使用的每个站点都提供不同的工具来进行模式匹配。所以我的问题是使用什么工具在管道流中进行简单的模式匹配。 上下文:我有named.conf 文件,我需要一个
我对 C 很陌生,我一直在尝试用这种数据结构制作一个程序: struct node { char command[100]; char prereq[100][80]; cha
该程序检查用户输入的数字是否为素数。 我的问题在if语句中。由于某些原因,Boolean永远不会切换。如果数字为质数,则只会给出两个结果。 我想念什么? import java.util.Scanne
我只是在学习 Haskell。我认为这会产生一个阶乘函数...... (在 ghci 内) Prelude> let ft 0 = 1 Prelude> let ft n = n * ft (n -
这个问题已经有答案了: Using bitwise OR 0 to floor a number (7 个回答) 已关闭 6 年前。 我试图在 JavaScript 中使用二分搜索来查找数组元素,并且
使用 Signal R,如果尝试发送对象,传递模型的语法是什么? private async void FormLoaded(object sender, RoutedEventArgs e) {
我需要使用 Javascript 生成一个半金字塔数字系列,其中包含输入的起始数字和 html 页面中的行数,并在 html 页面中显示结果。我已经完成了 Java 脚本编写之类的工作。我不明白的是它
为什么函数名重复 示例: lucky :: (Integral a) => a -> String lucky 7 = "LUCKY NUMBER SEVEN!" lucky x = "Sorry
我花了2天的时间在GGTS中使用grails进行Web开发。我正在跟着一本书。本书使用命令行。到目前为止,这很棒,但是现在这本书正在使用webtest。我已经在命令行上安装了webtest,但是如何在
我正在学习 Clojure,到目前为止我无法理解这个小难题,我确信这是非常基本的。 我有这个文件: (ns cloapp.core (:gen-class)) (defn -main "I d
我在获取图像以显示在我的 J Frame 中时遇到问题。我确信我将文件放在正确的位置并且输入了正确的名称。这是代码 import java.awt.Color; import java.awt.Gra
我正在尝试为我正在做的应用程序创建一个登录窗口。我整天都在寻找一个例子,但我似乎找不到任何有帮助的东西。我的基本结构如下: // App.scala object App extends Simple
坦率地说,我是 Java 新手。我正在开发一个项目,我想找到一种基于数字序列创建多项式函数的方法。 无论如何,我的问题是我创建了一个存储序列的数组。我现在想找出元素之间的差异。例如。我想找到这个计算a
现在添加了 xml 和 logcat,现在自定义 View 代码,不幸的是我远离开发计算机所以我无法检查你的建议,@jems,我的自定义 View 的构造函数可能错误?@Falmarri,我认为构建目
我在这里缺少什么?当我单击“h2 a”链接时,.content ol 应该切换。我不明白为什么它不起作用:( $(document).ready(function(){ $(".content ol
我是 Java 新手,我到处寻找,但我没有得到一个简单的概念。 我将两个变量声明为 int。我希望这两个变量对于所有方法都是全局的。在我的第一个方法中,我想从用户输入中获取第一个变量的值。然后我希望第
我正在抓取 IMDB 页面的数据,但当尝试将其写入 CSV 文件时,我只从结果中获取最后一行。 代码下方: from urllib.request import urlopen as uReq fro
自从我学习 C 语言以来,我决定制作一个简单的程序,用于加、减和计算两个变量的乘积。根据用户的输入是1,2还是3来选择加/减/折叠。 #include int main (void) { in
int main(void) { string n = GetString(); if(n!=NULL){ for(int i=0, j=strlen(n); i
我是一名优秀的程序员,十分优秀!