js实现数据绑定
来源:互联网 发布:知乎 暴戾 编辑:程序博客网 时间:2024/06/05 11:10
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>data-binding-method-set</title>
</head>
<body>
<input q-value="value" type="text" id="input">
<div q-text="value" id="el"></div>
<script>
var elems = [document.getElementById('el'), document.getElementById('input')];
var data = {
value: 'hello!'
};
var command = {
text: function(str){
this.innerHTML = str;
},
value: function(str){
this.setAttribute('value', str);
}
};
var scan = function(){
/**
* 扫描带指令的节点属性
*/
for(var i = 0, len = elems.length; i < len; i++){
var elem = elems[i];
elem.command = [];
for(var j = 0, len1 = elem.attributes.length; j < len1; j++){
var attr = elem.attributes[j];
if(attr.nodeName.indexOf('q-') >= 0){
/**
* 调用属性指令,这里可以使用数据改变检测
*/
command[attr.nodeName.slice(2)].call(elem, data[attr.nodeValue]);
elem.command.push(attr.nodeName.slice(2));
}
}
}
}
/**
* 设置数据后扫描
*/
function mvSet(key, value){
data[key] = value;
scan();
}
/**
* 数据绑定监听
*/
elems[1].addEventListener('keyup', function(e){
mvSet('value', e.target.value);
}, false);
scan();
/**
* 改变数据更新视图
*/
setTimeout(function(){
mvSet('value', 'fuck');
},1000)
</script>
</body>
</html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>data-binding-method-set</title>
</head>
<body>
<input q-value="value" type="text" id="input">
<div q-text="value" id="el"></div>
<script>
var elems = [document.getElementById('el'), document.getElementById('input')];
var data = {
value: 'hello!'
};
var command = {
text: function(str){
this.innerHTML = str;
},
value: function(str){
this.setAttribute('value', str);
}
};
var scan = function(){
/**
* 扫描带指令的节点属性
*/
for(var i = 0, len = elems.length; i < len; i++){
var elem = elems[i];
elem.command = [];
for(var j = 0, len1 = elem.attributes.length; j < len1; j++){
var attr = elem.attributes[j];
if(attr.nodeName.indexOf('q-') >= 0){
/**
* 调用属性指令,这里可以使用数据改变检测
*/
command[attr.nodeName.slice(2)].call(elem, data[attr.nodeValue]);
elem.command.push(attr.nodeName.slice(2));
}
}
}
}
/**
* 设置数据后扫描
*/
function mvSet(key, value){
data[key] = value;
scan();
}
/**
* 数据绑定监听
*/
elems[1].addEventListener('keyup', function(e){
mvSet('value', e.target.value);
}, false);
scan();
/**
* 改变数据更新视图
*/
setTimeout(function(){
mvSet('value', 'fuck');
},1000)
</script>
</body>
</html>
阅读全文
0 0
- js实现数据绑定
- js实现双向数据绑定
- 用原生js实现数据双向绑定
- js原生代码实现数据双向绑定
- js发布订阅实现双向数据绑定
- vue.js双向数据绑定实现原理
- 原生js 实现双向数据绑定
- js数据动态绑定
- Vue.js数据绑定
- vue.js数据绑定
- JS绑定表格数据
- highcharts实现js绑定ajax返回的数据集合
- Vue.js+Layer表格数据绑定与实现更新
- Vue.js+Layer表格数据绑定与实现更新
- Vue.js+Layer表格数据绑定与实现更新
- 原生JS实现angular的双向数据绑定
- 用实现数据绑定
- PasswordBox 实现数据绑定
- tensorflow将CSV文件转为TFrecords文件
- No215. Kth Largest Element in an Array
- (搬运).net起步 (自定义 ASP.NET CreateUserWizard 控件2)
- 13 linux设备驱动基础
- 素材 图论-节点的度
- js实现数据绑定
- 欢迎使用CSDN-markdown编辑器
- Double类型两个数不能用双等号判断是否相等
- 查看linux版本
- LintCode堆栈题总结
- 自学Java之Java编程(编写Java servlet和Java server)(021day)
- bp神经网络及matlab实现
- servletContext
- Keil 软件中运行程序时system viewer 不显示