- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
由于 my other jquery question 没有回复,我想将几行代码归零,以便您可以帮助我理解。首先,这个测验在按下按钮时运行多个问题,在我有限的理解中,这是直接的 DOM 操作,并且当人们在浏览器中“查看源代码”时不会显示。听起来对吗?
其次,我对以下几行感到困惑:
var input = '<input id="' + optionId + '" name="' + inputName +
'" type="' + inputType + '" /> ';
var optionLabel = '<label for="' + optionId + '">' + answer.option + '</label>';
var answerContent = $('<li></li>')
.append(input)
.append(optionLabel);
answerHTML.append(answerContent);
将这样的代码附加到空内容是否有意义
<li></li>
元素?我是否误读这是元素后面的附加内容?它似乎确实可以在另一个问题中列出的旧 jquery 版本下工作,但不能在新版本下工作(我猜测这是错误的根源,如另一个问题的图像所示,但我不确定)。
我刚刚尝试过:
var answerContent = '<li>' + input + optionLabel + '</li>';
它产生了相同的结果,仍然是一个错误,如图所示。
最佳答案
this is direct DOM manipulation and does not show up when one does "view source" in the browser
是的。不要使用“查看源代码”,在浏览器的开发者工具(F12)中查看 DOM。
Am I misreading that this is an append after the element?
是的。 http://api.jquery.com/append/
话虽如此,不要通过连接字符串来构建 HTML。一旦您使用的字符串包含在 HTML 中有意义的字符(例如 <
),这种情况就会中断。 , >
或&
。这至少可以发生在 answer.option
在这里。
jQuery 允许将元素属性作为带有键和值的对象传递,这使用起来很安全,并且需要更少的输入 ' + '
。对于像这样的简单情况就足够了。
$('<li></li>')
.append( $('<input>', {id: optionId, name: inputName, type: inputType}) )
.append( $('<label>', {htmlFor: optionId, text: answer.option}) )
.appendTo("#answerHTML");
这里的哲学是“创造一些东西,然后对其做一些事情”。请注意,正因为如此,此代码甚至不需要任何辅助变量。甚至没有answerHTML
需要是一个变量,只要目标元素可以通过选择器轻松选取即可。
对于更复杂的 DOM 构建情况,使用 jQuery 创建每一点都会变得乏味。使用 HTML 模板库,如 handlebars .
关于javascript - jQuery:为什么有人想要附加到一个封闭的列表元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46702187/
从the documentation, 13.5.5: When the last parameter of a method is a closure, you can place the clos
Bjarne Stroustrup 写道: “友元类必须事先在封闭范围内声明或在非类范围内定义,立即封闭声明它为友元的类” 语句的第一部分不是多余的,因为“立即包含类的非类范围”包括“先前在封闭范围中
我有一个网格(如下例),其中包含外墙(标记为 W)、环境 block (E)、开放空间 (o) 和事件点 (A)。目前,此网格存储在 [,] 中,其中包含与给定点关联的所有数据。我试图确定是否包含一个
我正在尝试使用 this blogpost's approach to higher-kinded data without dangling Identity functors for the tr
在下面的代码中: package main import ( "fmt" "time" ) func asChan(vs ...int) <-chan int { c := m
我在传递和评估闭包列表时遇到困难。经过大量简化,该程序显示出与我正在尝试编写的程序相同的错误: use std::vec::flat_map; #[main] fn main() { let li
我正在努力成为一名好公民,并尽可能远离全局范围。有没有办法访问不在全局范围内的 setTimeout 变量? 因此,在此示例中,某人将如何取消“计时器”? myObject.timedAction =
考虑这个例子: def A(): b = 1 def B(): # I can access 'b' from here. print(b)
val listPlans: List = newPlans.mapTry { it.data.map { Plan(it.id, it.nam
我目前正在尝试使用SinonJS对我的 angular.service 进行单元测试,但是遇到了一个问题,希望有人可以阐明为什么会发生这种情况。我已经重构了当前的项目以说明当前的问题。 我还提供了DE
我正在使用 Go channel ,我想知道关闭 channel 和将其设置为 nil 之间有什么区别? 编辑: 在此example ,我想通过关闭 channel 或设置为零来断开发送者和接收者的连
我的应用程序有一个奇怪的行为,我不知道它来自哪里。我已经为 TextView 内容实现了 NSScanner,效果非常好。扫描器与文本存储结合使用,通过 TextView 委托(delegate)方法
我不知道如何让 MyBatis 生成封闭的 or 语句: WHERE x.token = ? AND ( (x.scene = 'A' OR x.scene = 'B')) 这是一个令人惊讶的简单
我不希望这是一个摄像头检测程序。这是一个程序,可以检测应用程序屏幕上颜色的传递。 我想要做的是检测大于 5x5 像素的黑色何时穿过屏幕上定义的空间区域。我想过用一个大区域来拉伸(stretch)整个宽
我一直在使用 RDFLib 来解析数据并将其插入到三元组中。我遇到的一个常见问题是,从关联数据存储库解析时,没有尖括号括起 URL。 要上传数据,我必须手动添加 并使用 URIRef重新创建 URL。
我已经阅读了很多有关此问题的帖子,但我仍然不确定我是否完全理解这些定义。 以下是我认为不同术语的示例。我是否走在正确的轨道上,或者我仍然不理解这些概念。谢谢 Array - unbound and o
我为我的 Android 应用设置了 GooglePlay 内部和封闭式 Alpha 测试设置。 它非常适合允许测试人员加入计划并安装应用程序,但是当我从测试人员电子邮件列表中删除测试人员时,他们仍然
我是一名优秀的程序员,十分优秀!