时间:2021-05-26
玩过knockoutjs的都知道,有一个强大的功能叫做component,而这个component有个牛逼的地方就是拥有自己的viewmodel和template,比如下面这样:
很显然,viewmodel就是function函数区,而template就是模板区,然后通过register函数将component注册到knockout中,下面我们演示一个简单的功能,就是动态的显示当前“input”内容的length长度。
请仔细看一下这段代码,当前的component会将template模板inject到html的div的标签中,而且这个template标记中还有一个text元素的绑定,而这个(text().length)的数据源刚好就是viewModel中的this.text..对吧。。。有了这两个的合一,我们最后的html展示如下:
接下来我们随便输入一些数字,移开鼠标,这个时候会触发input的change事件,比如下面这样。
是不是好吊??? 当然有些人可能要问,如果在input呈现的时候赋予一点默认值呢???可不可以呢?当然也是可以的,这个时候我们可以在data-bind中默认赋予值就ok啦。。。比如下面这样:
可以看到,上面的代码中我通过在component中的params对象中加入一个initialText属性,这个时候就可以将这个initialText动态的注入到我们的viewModel中,然后我们的input和span元素通过data-bind 订阅了这个viewModel中的this.text监控属性,这个时候就出现了实时更新操作了,迫不及待的看一下吧~
一:问题分析
好了,通过上面的演示,你或许发现到了如下两个问题,第一个问题就是好强大,只要你register就可以了,根本不需要通过applyBindings来施加一个viewmodel,这样就实现了页面的模块化,真的好便捷~ 所以这个问题是一个好事情, 第二个问题就是我们的template模板中的内容是通过“硬编码“的形式,也就是如果这个内容有很多,比如有100行,200行,那我们是不是疯了??? 就是你能耐再大也没法一一拼接起来,就算拼起来,维护成本也太大了,所以问题来了,如何将template的content动态化??? 比如现实中我们看到的 百度文库 的页面。。。如下图:
这个页面中,有很多的模块,比如我圈出来的上面3个,这三个模块中的html肯定还是很多的吧~~~
二:template动态获取
html内容的动态获取,通常有两种方式,第一种就是RequireJs,当然你需要引用这么一个js,第二种就是我们重写他们的模板,当然这篇我们讲解后面的这种方式,我们要做的就是重写component中的loadTemplate函数,然后替换默认的defaultLoader加载器,是不是很简单呢???
1. 重写loadtemplate方法
2. 将hard codeing 放入到外部的file,比如我新建了一个file.html文件。
3. 再register组件,然后在template标记上引用外面文件路径,比如下面的{ fromUrl: 'file.html' }
好了,所有功能都准备完毕了,我们浏览一下页面,看看是啥样的???
终于大功搞成了,对不对撒~~~然后是不是就可以延伸到上面介绍的“百度文库”的例子,我们可以把各个模块的html放到一个单独的文件中.
<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title></title><meta charset="utf-8" /><script src="jquery-1.8.2.js"></script><script src="knockoutjs.js"></script></head><body><div data-bind='component: { name: "message-editor", params: { initialText: "你好撒!!!" }}'></div><script type="text/javascript">//第一步:重写loadTemplate方法var templateFromUrlLoader = {loadTemplate: function (name, templateConfig, callback) {if (templateConfig.fromUrl) {var fullUrl = '/' + templateConfig.fromUrl//ajax动态获取外部的file内容$.get(fullUrl, function (markupString) {ko.components.defaultLoader.loadTemplate(name, markupString, callback);});} else {callback(null);}}};//替换原来的defaultLoader,实现新的templateFromUrlLoaderko.components.loaders.unshift(templateFromUrlLoader);ko.components.register('message-editor', {viewModel: function (params) {this.text = ko.observable(params && params.initialText || '');},template: { fromUrl: 'file.html' },});ko.applyBindings();</script></body></html>以上所述是小编给大家介绍的knockoutjs动态加载外部的file作为component中的template数据源的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
业务需求提供所有微服务数据源的图形化维护功能代码生成可以根据选择的数据源加载表等源信息数据源管理要支持动态配置,实时生效附录效果图实现思路本文提供方法仅供类似简
本章目标整合Mybatis,并集成Druid数据源可视化监控Druid数据源使用JPA生成数据表利用注解实现数据库的事物利用注解动态配置数据源全局异常捕获校验请
mybatisplus多数据源切换mybatisplus多数据源切换使用注解@DSDS注解作为多数据源切点,具体实现作用主要由两个类完成DynamicDataS
此组件用于公共选择组件。引用VantUI作为样式特性:1、支持动态、静态数据源。2、支持分页加载。3、支持模糊搜索。4、支持单选、多选。组件源码:确认{{ite
此方案适用于解决springboot项目运行时动态添加数据源,非静态切换多数据源!!!一、多数据源应用场景:1.配置文件配置多数据源,如默认数据源:master