使用Knockout更改自定义jquery插件的设置
Change settings of custom jquery plugin using Knockout
我创建了一个非常基本的jquery插件。现在,我想使用knockoutjs来动态更新该插件的设置。我似乎不知道该怎么做,甚至不知道从哪里开始。这是我目前得到的。
<div class="mychart"></div>
<input type="text" data-bind="value: chartwidth"/>
<input type="text" data-bind="value: chartheight"/>
<script src="jquery.js"></script>
<script src="knockout.js"></script>
<script src="chartjs.js"></script>
<script>
$(".mychart").nbchart({
width:'200px',
height:'200px'
});
// Here's my data model
var ViewModel = function(cwidth,cheight) {
this.chartwidth = ko.observable(cwidth);
this.chartheight= ko.observable(cheight);
};
ko.applyBindings(new ViewModel("100px","100px"));
您可以做的最简单的事情就是订阅变量:
this.chartwidth.subscribe(function (newValue) {
$(".mychart").nbchart({width:newValue});
});
但是,您违反了Knockout的基本规则,即"不要在绑定处理程序之外混淆DOM"。
你的插件的自定义绑定处理程序应该是这样的:
ko.bindingHandlers.nbchart = {
init: function (element, valueAccessor) {
$(element).nbchart();
},
update: function (element, valueAccessor) {
var config = ko.unwrapObservable(valueAccessor());
$(element).nbchart({
width: config.width(),
height: config.height()
});
}
};
你会绑定像
这样的东西<div data-bind="nbchart:config"></div>
,你的视图模型有一个配置变量,如
var ViewModel = function(cwidth,cheight) {
this.chartwidth = ko.observable(cwidth);
this.chartheight= ko.observable(cheight);
config: {
width: this.chartwidth,
height: this.chartheight
}
};
最后,如果你不打算在没有Knockout的情况下使用这个插件,你不需要jQuery插件。您可以将所有的代码写入自定义绑定处理程序。
相关文章:
- 如何使用传单为传单实时插件设置自定义图标
- 无法调用方法'应用'关于为jquery谷歌地图插件设置方向的未定义
- 在jQuery UI选项卡中显示WordPress插件设置
- FullCalendar jQuery 插件 - 设置今天的日期
- JavaScript 插件设置优化
- 如何使用 eclipse-mars IDE 将 jquery 插件设置到我的 codeigniter 项目中
- 使用名为虔诚的jQuery图表插件设置多个if条件
- 如何使用angularjs中的自定义指令,使用Unform jQuery插件设置浏览器默认复选框的样式
- 如何在babel 6中定义插件设置
- jQuery XPath插件设置属性
- bootstrap TimePicker插件:设置完整的小时/分/秒
- jQuery cookie插件-设置和检索加载
- Jquery插件/设置间隔和范围问题
- 使用Iframe -resizer插件设置高度为0的Iframe
- 在jQuery插件设置中使用特殊字符
- 使用jquery cookie插件设置body类
- 为YUI日历插件设置时区
- 将jquery自动完成插件设置为自动提交
- jQuery selectionBox插件-设置默认文本选择选项
- jSlider jQuery插件:设置最小范围,并格式化最小值