加载依赖于页面的面向对象JS属性的最好方法是什么?
Whats the best way to load Object Oriented JS properties dependent on page?
我有一个外部JS脚本文件,里面有我所有的对象,一旦文档准备好了,就会运行,就像这样…
jQuery(function($) {
var Main = {
run: function () {
myFunction.setup();
}
}
var myFunction = {
setup: function() {
//Do some stuff here
}
}
Main.run();
});
我希望能够运行myFunction.setup()只有当我在某个页面上,虽然否则我会得到错误,如果该方法正在寻找页面上不存在的元素,例如幻灯片,菜单等
目前,我已经通过检查元素是否存在。length来绕过这个问题,如果它存在,那么运行方法的其余部分,但我想知道是否有更好的方法?也许就像如果它是可以发送变量到脚本文件时,它加载基于页面上,所以它知道什么方法运行?
任何帮助都将非常感激。
感谢贾尔斯Paul Irish有一个很好的方法来做到这一点,使用body标签中的ID和类来执行特定的代码块:
http://paulirish.com/2009/markup-based-unobtrusive-comprehensive-dom-ready-execution/这类事情可能会有所帮助:
页面特定
var page_config = {
setup_allowed: true
// ... more config
};
的
var Main,
myFunction;
(function ($, _config) {
myFunction = (function () {
var _public = {};
if (_config.setup_allowed === true) {
_public.setup = function () {
};
}
return _public;
})();
Main = (function () {
var _public = {};
if (typeof myFunction.setup !== "undefined") {
_public.run = function () {
myFunction.setup();
};
// Run it as we had Main.run() before
_public.run();
}
return _public;
})();
})(jQuery, page_config);
这样Main.run()
和myFunction.setup()
只有在page_config
中指定时才可用。
下面是一个工作示例,您可以试用一下。对于您的特定需求,这可能有点冗长,但希望它能在某种程度上有所帮助:-)
相关文章:
- 打破承诺链的好方法是什么
- 在JavaScript中拆分日期字符串的更好方法是什么
- 将jQuery.ech()方法转换为本地JavaScript抽象的最佳方法是什么
- 处理浮点错误的最佳方法是什么
- 基于窗口宽度jquery的函数的替代方法是什么
- knex:根据结果创建数组的合适方法是什么
- 以编程方式填充组合框道场 (1.8) 的最佳方法是什么?
- 使用Modernizr检测移动设备最可靠的方法是什么
- 确定var是否是javascript中的elementFinder对象的方法是什么
- 用javascript修复这个JSON对象字符串最干净的方法是什么
- 让会话值可用于JavaScript的好方法是什么
- 从AngularJs获取谷歌地图对象的正确方法是什么
- 使用ReactJS和Flux架构从服务器获取数据的正确方法是什么
- 列出没有 mysql 的元素的最佳方法是什么
- 克服错误的更优雅的方法是什么:需要对象说明符.当通过JXA通过Messages发送SMS时,参数没有对象说明符
- 使用较少代码隐藏和显示选择菜单内容的更好方法是什么?javascript
- 在 Javascript 中实现解耦代码/回调的正确方法是什么?
- 使用Javascript,获取元素的方法是什么,基于打开和关闭标记之间的文本
- 在d3.json中使用d3.csv组合多个csv文件数据输入的最佳方法是什么
- 直接在DOM事件处理程序中调用作用域函数的最短方法是什么