为了账号安全,请及时绑定邮箱和手机立即绑定

如何在特定 div 中强制运行 JS 函数

如何在特定 div 中强制运行 JS 函数

慕哥6287543 2022-08-04 10:34:44
我正在尝试用js构建表,但我无法强制它在特定的div中构建,它总是在整个部分之外创建我的表。有什么办法可以强迫它吗?网页:<section class="all-products" id="all-products">    <div class="container">        <div class="title-box">            <h2>Products</h2>        </div>        <div class="row" id=products-row">            <script>              LoadAllProducts();            </script>        </div>    </div></section>负载产品.js:function LoadAllProducts() {    var x = document.createElement("TABLE");    x.setAttribute("id", "table");    document.body.appendChild(x);    var y = document.createElement("TBODY");    y.setAttribute("id", "products");    document.getElementById("table").appendChild(y);}
查看完整描述

2 回答

?
萧十郎

TA贡献1815条经验 获得超13个赞

问题是您正在调用 .appendChild()body


function LoadAllProducts() {

    var x = document.createElement("TABLE");

    x.setAttribute("id", "table");

    // Instead of document.body, use document.getElementById()

    document.getElementById("products-row").appendChild(x);


    var y = document.createElement("TBODY");

    y.setAttribute("id", "products");

    // ... like you were using here...

    document.getElementById("table").appendChild(y);

}


函数调用在HTML中的位置并不重要,都会引用当前页面的元素。document.bodybodydocument


查看完整回答
反对 回复 2022-08-04
?
守候你守候我

TA贡献1802条经验 获得超10个赞

 document.body.appendChild(x);

显然是 document.body。该程序正在完全按照您的指示执行操作...将节附加到文档的正文。

该程序不理解“含义”,例如“我把这个代码放在这里,所以我期望代码在这里输出”。JavaScript DOM 不是这样工作的。您必须指定输出的去向。

如果你想让它出现在产品行中,你必须告诉它去那里

document.getElementById("products-row").appendChild(x)

在这种情况下,我们通过id获取元素“products-rows”,然后告诉代码“在这里附加我的输出x”。


查看完整回答
反对 回复 2022-08-04
  • 2 回答
  • 0 关注
  • 204 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号