gpt4 book ai didi

javascript - 将 JavaScript 操作与 DOM 集成的最佳实践

转载 作者:行者123 更新时间:2023-12-02 20:47:46 25 4
gpt4 key购买 nike

例如,我们假设一个 xHTML 文档如下:

<html>
<head>
</head>
<body>
<div id="wrapper">
<div id="sidebar"></div>
<div id="content"></div>
</div>
</body>
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
<script type="text/javascript" src="./application.js"></script>
</html>

我们将向 PHP 脚本执行 GET AJAX 请求,该脚本将查询数据库并返回响应以填充 TABLE 元素,该元素将通过 JavaScript 格式化为可排序网格。

此外,我们希望将所有 JavaScript 放在一个文件中,该文件可以轻松包含,如上所示。

选项:

  1. 让 PHP 脚本返回 TABLE元素填充了所有数据。使用 jQuery 的 live() 函数积极观察新的TABLEDOM 中的元素并应用可排序的网格功能发现他们。该方法允许我们在 PHP 中操作从 AJAX 请求返回的内容,并将完整的语义表返回给父文档。

  2. TABLE 元素插入上面列出的脚本中,但将其内容保留为空。一旦文档准备好,jQuery 将立即应用可排序网格功能,尽管尚不存在任何内容。然后,GET 请求将返回一个 JSON 响应,该响应将填充数据库。

对于此类事情,您还有什么其他意见/最佳实践/用例可以分享吗?我在这里只讨论一个TABLE,但我们一直在讨论很多东西的问题:灯箱、下拉菜单等。

目前,我们没有使用 jQuery 的 live() 函数,父文档中也不存在 DOM 元素。因此,我们必须在每个单独 View 的顶部放置一小段 Javascript。虽然很草率,但这使得我们只能在需要时才加载功能,但显然很难维护。

最佳答案

最好在初始加载时加载尽可能多的内容。如果您的网站/应用程序要求您通过 AJAX 动态添加内容,那么我可以看到您的困境。

据我了解,您想知道保持 JavaScript 简洁并保存在文件中而不是分散在整个页面中的最佳/首选做法是什么。您是说,目前您的脚本分散在整个页面中,因为当您加载模块/ View 或其他任何内容时,它们会附带 js,以便在加载时运行脚本(长篇大论,抱歉)。而且,问题在于,当使用一个万能的 super 全局 js 文件加载这些 View 时,您希望触发特定事件(例如实例化灯箱或对表格进行排序)。

所以,如果这听起来不错,那么这就是我要做的(对于动态加载的任何 View )...

因此,假设您拥有提供的代码:

<html>
<head>
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"z></script>
<script type="text/javascript" src="./application.js"></script>
</head>
<body>
<div id="wrapper">
<div id="sidebar"></div>
<div id="content"></div>
</div>
</body>
</html>

如果您在页面完全加载时将一些内容加载到“#content”div(例如,表格)中,然后您想要对该表格进行排序,而不将脚本放入从返回的 HTML 中执行此操作AJAX,您可以在主('./application.js')文件中包含以下代码:

$(function() {
load_table();
$('#content #my_table').live('table_loaded',function() {
$(this).sort(); // or whatever your sorting method is...
});
});

function load_table() {
$.get('mysite.php',{foo:bar,bar:foo},function(data) {
$('#content').html(data).find('#my_table').trigger('table_loaded');
});
}

这使用了 jquery 自定义事件和 live() 事件。我还没有对此进行测试,但理论上它应该有效。

更新:我对此进行了测试,它使用 jquery 1.3.2 完美运行:)

关于javascript - 将 JavaScript 操作与 DOM 集成的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/698135/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com