0
我正在jquery插件上工作,我遇到了問題,保存屬性供以後使用。在下面的示例中,當我在尋找18, 50, 18
時,控制檯輸出爲18, 50, 50
。我明白爲什麼會發生這種情況,但我無法找出一種好方法來保存properties
以用於多種不同的方法。我有一種感覺,我錯過了一些非常明顯的東西,但我只是沒有看到它。jQuery插件存儲值
<html>
<body>
<h1>Hello</h1>
<h2>World</h2>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.0/jquery.min.js"></script>
<script type="text/javascript">
(function ($) {
var commonOperations, methods, properties;
commonOperations = function() {
console.log(properties.height);
};
methods = {
init : function (overrides) {
var defaults;
defaults = { height: 18 };
properties = $.extend(defaults, overrides);
commonOperations();
},
foo : function() {
commonOperations();
}
};
$.fn.myPlugin = function (method) {
if (methods[method]) {
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method === 'object' || !method) {
return methods.init.apply(this, arguments);
} else {
$.error('Method ' + method + ' does not exist for jQuery.myPlugin');
}
};
}(jQuery));
$(document).ready(function() {
$("h1").myPlugin();
$("h2").myPlugin({ height: 50 });
$("h1").myPlugin("foo");
});
</script>
</body>
</html>
+1 - 支持信息可以在這裏找到:http://docs.jquery.com/Plugins/編寫#數據 – 2012-04-05 21:41:28
謝謝。這很有道理。 – Jason 2012-04-05 21:43:52