首页 >> js开发 >> js代码原生javascript实现类似vue的数据绑定功能示例【观察者模式】
js代码原生javascript实现类似vue的数据绑定功能示例【观察者模式】
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
本文实例讲述了原生javascript实现类似vue的数据绑定功能。分享给大家供大家参考,具体如下:观察者模式
let observer = {
/*订阅功能*/
addSubscriber: function (cb) {
this.subscribers.push(cb);
},
/*退订功能*/
removerSubscriber: function (cb) {
let index = this.subscribers.indexOf(cb);
this.subscribers.splice(index, 1)
},
// 发布功能
publish: function (what) {
for (let i in this.subscribers) {
if (typeof this.subscribers[i] == "function") {
this.subscribers[i](what);
}
}
},
// 让每个对象具有订阅功能
make:function(obj){
for(let key in this){
obj[key] = this[key];
}
obj.subscribers = [];
},
}
let observer = {
/*订阅功能*/
addSubscriber: function (cb) {
this.subscribers.push(cb);
},
/*退订功能*/
removerSubscriber: function (cb) {
let index = this.subscribers.indexOf(cb);
this.subscribers.splice(index, 1)
},
// 发布功能
publish: function (what) {
for (let i in this.subscribers) {
if (typeof this.subscribers[i] == "function") {
this.subscribers[i](what);
}
}
},
// 让每个对象具有订阅功能
make:function(obj){
for(let key in this){
obj[key] = this[key];
}
obj.subscribers = [];
},
}
使用实例
// 定义对象
let o = {};
// 实现数据绑定 实现具有发布订阅功能
observer.make(o);
// 发布
$("#num").oninput = function(){
o.publish(this.value);
};
// 平方功能
o.addSubscriber(function(num){
$("#sqrnum").value = Math.pow(num,2);
});
o.addSubscriber(function(num){
$("#cubenum").value = Math.pow(num,3);
});
o.addSubscriber(function(num){
$("#fourFangnum").value = Math.pow(num,4);
});
o.addSubscriber(function(num){
$("#sqrtnum").value = Math.sqrt(num);
});
}
function $(str){//#box .cls p
if(str.charAt(0)=="#"){
return document.getElementById(str.substring(1));
}else if(str.charAt(0)=="."){
return document.getElementsByClassName(str.substring(1));
}else{
return document.getElementsByTagName(str);
}
}
// 定义对象
let o = {};
// 实现数据绑定 实现具有发布订阅功能
observer.make(o);
// 发布
$("#num").oninput = function(){
o.publish(this.value);
};
// 平方功能
o.addSubscriber(function(num){
$("#sqrnum").value = Math.pow(num,2);
});
o.addSubscriber(function(num){
$("#cubenum").value = Math.pow(num,3);
});
o.addSubscriber(function(num){
$("#fourFangnum").value = Math.pow(num,4);
});
o.addSubscriber(function(num){
$("#sqrtnum").value = Math.sqrt(num);
});
}
function $(str){//#box .cls p
if(str.charAt(0)=="#"){
return document.getElementById(str.substring(1));
}else if(str.charAt(0)=="."){
return document.getElementsByClassName(str.substring(1));
}else{
return document.getElementsByTagName(str);
}
}
感兴趣的朋友可以使用在线HTML/CSS/JavaScript前端代码调试运行工具:http://tools./code/WebCodeRun测试上述代码运行效果。在线HTML/CSS/JavaScript前端代码调试运行工具在线HTML/CSS/JavaScript前端代码调试运行工具http://tools./code/WebCodeRun关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》javascript面向对象入门教程JavaScript错误与调试技巧总结JavaScript数据结构与算法技巧总结JavaScript遍历算法与技巧总结JavaScript数学运算用法总结希望本文所述对大家JavaScript程序设计有所帮助。
let observer = {
/*订阅功能*/
addSubscriber: function (cb) {
this.subscribers.push(cb);
},
/*退订功能*/
removerSubscriber: function (cb) {
let index = this.subscribers.indexOf(cb);
this.subscribers.splice(index, 1)
},
// 发布功能
publish: function (what) {
for (let i in this.subscribers) {
if (typeof this.subscribers[i] == "function") {
this.subscribers[i](what);
}
}
},
// 让每个对象具有订阅功能
make:function(obj){
for(let key in this){
obj[key] = this[key];
}
obj.subscribers = [];
},
}
let observer = {
/*订阅功能*/
addSubscriber: function (cb) {
this.subscribers.push(cb);
},
/*退订功能*/
removerSubscriber: function (cb) {
let index = this.subscribers.indexOf(cb);
this.subscribers.splice(index, 1)
},
// 发布功能
publish: function (what) {
for (let i in this.subscribers) {
if (typeof this.subscribers[i] == "function") {
this.subscribers[i](what);
}
}
},
// 让每个对象具有订阅功能
make:function(obj){
for(let key in this){
obj[key] = this[key];
}
obj.subscribers = [];
},
}
使用实例
// 定义对象
let o = {};
// 实现数据绑定 实现具有发布订阅功能
observer.make(o);
// 发布
$("#num").oninput = function(){
o.publish(this.value);
};
// 平方功能
o.addSubscriber(function(num){
$("#sqrnum").value = Math.pow(num,2);
});
o.addSubscriber(function(num){
$("#cubenum").value = Math.pow(num,3);
});
o.addSubscriber(function(num){
$("#fourFangnum").value = Math.pow(num,4);
});
o.addSubscriber(function(num){
$("#sqrtnum").value = Math.sqrt(num);
});
}
function $(str){//#box .cls p
if(str.charAt(0)=="#"){
return document.getElementById(str.substring(1));
}else if(str.charAt(0)=="."){
return document.getElementsByClassName(str.substring(1));
}else{
return document.getElementsByTagName(str);
}
}
// 定义对象
let o = {};
// 实现数据绑定 实现具有发布订阅功能
observer.make(o);
// 发布
$("#num").oninput = function(){
o.publish(this.value);
};
// 平方功能
o.addSubscriber(function(num){
$("#sqrnum").value = Math.pow(num,2);
});
o.addSubscriber(function(num){
$("#cubenum").value = Math.pow(num,3);
});
o.addSubscriber(function(num){
$("#fourFangnum").value = Math.pow(num,4);
});
o.addSubscriber(function(num){
$("#sqrtnum").value = Math.sqrt(num);
});
}
function $(str){//#box .cls p
if(str.charAt(0)=="#"){
return document.getElementById(str.substring(1));
}else if(str.charAt(0)=="."){
return document.getElementsByClassName(str.substring(1));
}else{
return document.getElementsByTagName(str);
}
}
感兴趣的朋友可以使用在线HTML/CSS/JavaScript前端代码调试运行工具:http://tools./code/WebCodeRun测试上述代码运行效果。在线HTML/CSS/JavaScript前端代码调试运行工具在线HTML/CSS/JavaScript前端代码调试运行工具http://tools./code/WebCodeRun关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》javascript面向对象入门教程JavaScript错误与调试技巧总结JavaScript数据结构与算法技巧总结JavaScript遍历算法与技巧总结JavaScript数学运算用法总结希望本文所述对大家JavaScript程序设计有所帮助。
相关文章:
- js代码详解JavaScript匿名函数和闭包
- jsuniapp,微信小程序中使用 MQTT的问题js大全
- JavaScript基于原生js实现判断元素是否有指定class名
- jsVSCode 配置uni-app的方法js大全
- jsElement图表初始大小及窗口自适应实现js大全
- jsVue watch响应数据实现方法解析js大全
- js基于小程序请求接口wx.request封装的类axios请求js大全
- js通过实例解析chrome如何在mac环境中安装vue-devtools插件js大全
- jsJs on及addEventListener原理用法区别解析js大全
- jsJS sort方法基于数组对象属性值排序js大全