knockoutjs动态加载外部的file作为component中的templ(2)

ko.components.register('message-editor', { viewModel: function (params) { this.text = ko.observable(params && params.initialText || ''); }, template: { fromUrl: 'file.html' }, });

好了,所有功能都准备完毕了,我们浏览一下页面,看看是啥样的???

knockoutjs动态加载外部的file作为component中的templ

终于大功搞成了,对不对撒~~~然后是不是就可以延伸到上面介绍的“百度文库”的例子,我们可以把各个模块的html放到一个单独的文件中.

<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title></title> <meta charset="utf-8" /> <script src="https://www.jb51.net/jquery-1.8.2.js"></script> <script src="https://www.jb51.net/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 = 'https://www.jb51.net/' + templateConfig.fromUrl //ajax动态获取外部的file内容 $.get(fullUrl, function (markupString) { ko.components.defaultLoader.loadTemplate(name, markupString, callback); }); } else { callback(null); } } }; //替换原来的defaultLoader,实现新的templateFromUrlLoader ko.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数据源的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wzfgfx.html