- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这应该很容易,但在研究了 DOM 并仔细阅读了 SO 上的相关帖子后,我仍然不明白。
我有一个最外面的 div,其中嵌套了 4 个 div。 4 个嵌套 div 中的每一个都有一个嵌套在其中的输入 type="text"。
我在最外面的包含 div 中添加了一个 onclick,以便单击 4 个嵌套 div 或 input type="text"元素中的任何一个都会调用一个“onclick”处理程序。
在 onclick 处理程序中,我还需要获取 4 个文本输入以及 4 个嵌套 div 的 id、名称和值。
这是代码。
<div class="itemlistRowContainer" id="topmostDiv ID" onclick="handleRowClick(this);"
name="itemlistRowContainer Div name" value="itemlistRowContainer Div Value">
<div class="itemListRowElementLeftMost" name="itemListRowElementLeftMost Div name"
value="itemListRowElementLeftMost Div value">Item<br />
<input type="text" size="30" maxlength="50" id="itemName_id"
name="itemName" value="$itemname" readonly="readonly"></input>
</div>
// 3 more divs and nested text input pairs not shown for brevity
</div>
这是 onclick 事件处理程序 - 请注意上面在最外面的 div 中,我将“this”传递给 onclick() 处理程序,从我读到的各种 SO 帖子中,我相信“this”将最外面的 div 本身传递给onclick 处理程序:
function handleRowClick(theElement)
{
var childNodes = theElement.childNodes;
var numChildNodes = childNodes.length;
alert("handleRowClick: childNodes array has length = " + numChildNodes);
for(i = 0; i < numChildNodes; i++)
{
alert("The DOM element " + i + " has innerHTML = " + childNodes[i].innerHTML + ", "
+ "nodeName = " + childNodes[i].nodeName + ", "
+ "nodeType = " + childNodes[i].nodeType + ", "
+ "nodeValue = " + childNodes[i].nodeValue + ", "
+ "parentNode = " + childNodes[i].parentNode + ", "
+ "childNodes = " + childNodes[i].childNodes + ", "
+ "attributes = " + childNodes[i].attributes + ", "
+ "name = " + childNodes[i].name + ", "
+ "value = " + childNodes[i].value + ", "
+ "id = " + childNodes[i].id);
}
上面的第一个alert()显示childNodes数组中有9个数组元素。
当“for”循环执行时,它告诉我数组中有两种类型的 DOM 元素:
有 5 个报告为:nodeName=#text、nodeType = 3、 和 value=id=name=undefined
并且有 4 个 childNode[] 元素报告为:nodeName=DIV,nodeType = 1, 和再次 - value=name=id=undefined。
在我看来——在 onclick 处理程序中,我正确地传递了 4 个嵌套 div (nodeType 1) 和 4 个只读文本字段,nodeType=#text,nodeType=3,输入类型=文本。
然后“for”循环报告的第 9 个也是最后一个元素是——一个额外的 nodeName=#text 元素(nodeType = 3),我不知道那是什么——如果它是最外面的 div,然后它会像 4 个内部 div 一样具有 nodeType=1 和 nodeName=div。
很好,花花公子。但到底为什么 id、名称和值无法帮助我找出哪个是哪个?
对于 DIV 节点,innerHTML 具有嵌套在其中的输入 type=text 的 html 标签,但我不打算解析它——输出(在上面“for”循环的alert()框中)对于 DIV 节点是这样的:
The DOM element 1 has innerHTML = Item<br>
<input size="30" maxlength="50" id="itemName_id" name="itemName"
value="f's first item" readonly="readonly"
type="text">
, nodeName = DIV, nodeType = 1, nodeValue = null,
parentNode = [object HTMLDivElement], childNodes = [object
NodeList], attributes = [object NamedNodeMap],
name = undefined, value = undefined, id =
我的问题是,当我的 onclick 处理程序被调用时,我需要获取 4 个包含的 DIV 和 4 个包含的输入 type=text 元素中每一个的 id、名称、值 - 如何获取?为什么它们都是“未定义”,因为当我的 onclick() 处理程序被调用时,我确实可以访问 4 个嵌套的 div 和 4 个文本字段。
最佳答案
最外面的 div 有 4 个子 div。因此,theElement.childNodes.length
应该为您提供 4。这是您看到的 4 个 nodeName = DIV、nodeType = 1 结果。每个输入元素都是内部 div 的子元素。 theElement.childNodes
将不会返回输入元素。神秘的nodeType = 3条目是文本节点。考虑以下片段
<div>
<div>text in innerdiv</div>
text in outer div
</div>
外部 div 有两个子节点 - 一个嵌套 div 和文本 外部 div 中的文本
尝试使用
function handleRowClick(theElement)
{
var childDivs = theElement.getElementsByTagName("div");
var childInputs = theElement.getElementsByTagName("input");
for(i = 0; i < childDivs.length; i++)
{
//process child divs here
}
for (i=0; i<childInputs.length; i++ )
{
//process child inputs here
}
}
关于javascript - 如何获得 4 <div> 和 4 <input type 'id' > 的 ="text",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9338421/
我目前正在创建一个正则表达式来拆分所有匹配以下格式的字符串:&[text(text - text text) !text]。这里的文本实际上可以是任何字符。并且间距很重要。文本将如图所示列出。 我已经
这个问题在这里已经有了答案: Remove duplicate commas and extra commas at start/end with RegExp in Javascript, and
我有以下代码。 from xml.dom.minidom import Document doc = Document() root = doc.createElement('root') doc.a
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Find text string in jQuery and make it bold 如何使用 jQuer
我使用 libmagic 在我的元素的 Web 界面中获取文件的 MIME 类型。我在 css 和 js 文件上得到文本/纯 mime 类型。 例如 chromium 显示以下警告: Resource
起初我必须阅读很多教程,但我仍然不知道我做错了什么...... 我想内联使用 4 个 div。在我想放置的那些 div 中:文本、图像、文本、文本。我希望中间文本自动设置为最大宽度。 我写了一个简单的
我想替换所有出现的 [b: "text"]至text使用 JavaScript 和 RegEx。目前我知道如何替换 [b: ""]至使用'/\[b: ""\]/g'但我不知道如果 " 之间有文本该怎么
这可能是一个幼稚的问题,但我想知道是否有比使用 text() 更好的方法将文本添加到绘图中。注意,我也在使用 layout()以及。具体来说,我有一个情节的一部分,我想在其中添加一些带有标题的文本,然
我必须反复从 latex 源粘贴代码,因此每次都必须做很多查找和替换操作('“a'=>'ä','” o'=>'ö',...) 。 有没有一种方法可以存储这些搜索和替换规则,例如,我可以通过一次按键执行
当我在Sublime Text 3代码屏幕中编写代码时,它连续地向右滑动,如图所示。我该怎么办? 请注意第10行。 最佳答案 如果您只想为当前 View (正在编辑的当前文件)激活自动换行,只需vie
是否有可能更改 sublime text 中的默认字体目录?我只想使用可移植 sublime 文本存储在我的 pendrive 上的字体,这样我就不必在我使用可移植 sublime 文本的每台机器上安
我是 Android 开发的新手,我有一个愚蠢的问题。如何将“文本字段”框放在一行中的文本旁边。 例子: Please Enter the number: [ ] 关于 "t
我想自动将“我的文本”更改为“我的文本”,因为这是用德语写的正确方式。引号可以在文本中的任何位置。 有没有一种简单的方法可以实现这一点? 解决方案应该检查第一个字符,最后一个字符,比如“this”,或
我想知道是否有特殊的语法来绑定(bind)与现有文本连接的文本。 像这样。 显然,这行不通。 什么是最佳实践? 使用 SL4。 最佳答案 使用StringFormat在 Binding 上。 WPF
我认为它应该打印“真实文本”,因为它相当于 true console.log('true text' || true ? 'text' : 'text1'); 但是,输出是“文本”;抱歉,如果是愚蠢的
有没有办法通过 css 打破文本,以便中间有一个“空白”?目前我正在通过手工打破文本来解决这个问题 -但这是愚蠢的。我知道有一个函数可以让文本在另一个 div 中结束和开始,但 IE 不支持它。 文本
我想为我的Tcl/Tk工具实现一个效果:在text控件中,根据具体情况,希望高亮一些线条的背景色,其他线条正常透明.有可能吗? 我尝试了一些选项,例如:-highlightbackground 、-i
我正在尝试解析原始维基百科文章内容,例如the article on Sweden ,使用re.sub()。但是,我在尝试替换 {{some text}} block 时遇到了问题,因为它们可以包含更
我试图先删除 ComboBox 中的所有内容。然后在其前面添加文本,但保留了一些旧文本。有没有办法重置或清除 ComboBox?或者我怎样才能最好地实现这一目标? public void GetBad
我知道我们应该创建 Example对象并将其传递给 nlp.update() 方法。根据 docs 中的示例, 我们有 for raw_text, entity_offsets in train_da
我是一名优秀的程序员,十分优秀!