js简单双向绑定案例代码(js如何实现双向绑定)

本文目录一览:

实现双向数据绑定

MVVM框架主要包含3个部分: model 、 view 和 viewmodel 。

简单的来说,就是框架的控制器层(这里的控制器层是一个泛指,可以理解为控制view行为和联系model层的中间件)和UI展示层(view层)建立一个双向的数据通道。当这两层中的任何一方发生变化时,另一层将会自动作出相应的变化。

一般来说要实现这种双向数据绑定,在前端我目前了解的有三种形式:

目前angular,regular的实现都是基于脏检查。当发生某些特定的事情的时候,框架会调用相关的digest方法。内部逻辑就是遍历所有的 watcher ,对监控的属性做对比。如果值发生了变化,则执行相应的 handler 。

当系统进入脏检查阶段,遍历所有的 $watch 绑定的 watcher ,然后对比 watcher.get() 与 watcher.last ,如果不同则运行对应的 watcher.fn(newvalue, oldvalue) 。然后再进入下一个watcher的检查。

何时进行脏检查?

由于regularjs是基于脏检查,所以当不是由regularjs本身控制的操作(如事件、指令)引起的数据操作,可能需要你手动的去同步data与view的数据. $update方法即帮助将你的data同步到view层.

]( )元素来控制你的观察者数量。

使用ES7中的 Object.observe 方法对对象(或者其属性)进行监控观察,一旦其发生变化时,将会执行相应的handler。这是目前监控属性数据变更最完美的一种方法,语言(浏览器)原生支持,没有什么比这个更好了。唯一的遗憾就是目前支持广度还不行,有待全面推广。

vue.js和avalon.js实现数据双向绑定的原理就是属性访问器。

它使用了ES5中的定义标准属性的Object.defineProperty 方法。

Object.defineProperty 使用示例:

首先,vuejs在实例化的过程中,会对遍历传给实例化对象选项中的data 选项,遍历其所有属性并使用 Object.defineProperty 把这些属性全部转为 getter/setter。

同时每一个实例对象都有一个watcher实例对象,他会在模板编译的过程中,用getter去访问data的属性,watcher此时就会把用到的data属性记为依赖,这样就建立了视图与数据之间的联系。当之后我们渲染视图的数据依赖发生改变(即数据的setter被调用)的时候,watcher会对比前后两个的数值是否发生变化,然后确定是否通知视图进行重新渲染。这样就实现了所谓的双向数据绑定。

js实现数据双向绑定

我们主要通过ES5中的 Object.defineProperty 实现,主要是利用里面的 get 和 set 来实现数据双向绑定

以上没满足知识量的可查看详情 : 双向绑定原理详情

以上就是对ES5中Object.defineProperty实现双向数据绑定的理解

vuejs怎样实现列表中checkbox的双向绑定及初始化渲

1.双向绑定可以绑定到同一个数组

input type=”checkbox” value=”Jack” v-model=”checkedNames”

label for=”jack”Jack/label

input type=”checkbox” value=”John” v-model=”checkedNames”

label for=”john”John/label

input type=”checkbox” value=”Mike” v-model=”checkedNames”

label for=”mike”Mike/label

br

spanChecked names: {{ checkedNames | json }}/span

这样可以不做任何处理,获得所有checked的checkbox。

2.可是如果需要初始化渲染,一部分checkbox被预选中,v-model需要绑定一个boolen值checked:

tr v-for=”item in list”

td

input type=”checkbox” :value=”item.value” v-model=”item.checked” /

/td

/tr

new Vue({

el: ‘body’,

data: {

list: [{checked:true,value:’a’},{checked:false,value:’b’}]

}

});

Vue.js(读音 /vjuː/, 类似于 view)是一个构建数据驱动的 web 界面的渐进式框架。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。它不仅易于上手,还便于与第三方库或既有项目整合。

另一方面,当与单文件组件和 Vue 生态系统支持的库结合使用时,Vue 也完全能够为复杂的单页应用程序提供驱动。

Vue.js入门教程(三)双向绑定和数据渲染

既然清楚了原理,那么,接下来进入正题——我知道了vue怎么安装,那么我怎么使用呢?

在告诉你基础用法之前,我还是要先告诉你一个情况。

可能要令你有点失望。vue主要是侧重于数据端的。他的目的就是渲染数据和在前端调整一下数据逻辑。

他不是像jquery那样让你用来做特技的。就算你要做特技。你也应该通过css3/canvas而不是dom。

所谓的双向绑定,你可以理解就是把view。(你还不清楚mvc的话,请看第一章)

和model绑定到一起。说白了,就是你js中的绑定值变了。你dom中的内容就跟着一块变了。

vue是通过解析{{文字..}}来生成内容的。后面绑定方法,输出内容的时候都会讲到。

列表输出使用 v-for,这些v开头加横杠的叫做命令

这些命令是可以自定义的。但是那都属于高级操作,我们不用它也完全足够支撑做一个大型项目了。

其实你回发现,这里无论是v-for或者是v-什么其他玩意

它都深刻的遵循了es6的语法。这里不就是一个典型的for in 循环吗。不过我们现在都用for of了。

你记住这个用法,它就长这样。

前后端分离开发的关键在于:后台只提供接口。

我们获得的数据多数情况下,仅仅是一个json,而mvvm的关键就再于解析数据在前端完成了。如果你了解jsp或者php你会了解,数据的解析在mvc中,

是由后端完成的,而html只负责显示。

所以,当你了解了数据绑定和渲染以后,你可以第一时间先把数据输出到页面了。

我们前端最厉害的地方不就是处理能看得见的东西吗?

vuejs怎样实现列表中checkbox的双向绑定及初始化渲染

双向绑定可以绑定到同一个数组

input type=”checkbox” id=”jack” value=”Jack” v-model=”checkedNames”

label for=”jack”Jack/label

input type=”checkbox” id=”john” value=”John” v-model=”checkedNames”

label for=”john”John/label

input type=”checkbox” id=”mike” value=”Mike” v-model=”checkedNames”

label for=”mike”Mike/label

br

spanChecked names: {{ checkedNames | json }}/span

这样可以不做任何处理,获得所有checked的checkbox。

可是如果需要初始化渲染,一部分checkbox被预选中,v-model需要绑定一个boolen值checked:

tr v-for=”item in list”

td

input type=”checkbox” :value=”item.value” v-model=”item.checked” /

/td

/tr

new Vue({

el: ‘body’,

data: {

list: [{checked:true,value:’a’},{checked:false,value:’b’}]

}

});

利用 filter , map 来完成

methods: {

getChecked: function() {

// 先透过 filter 筛选出 checked 为 true 的 item

// 在透过 map 只回传 item 的 value

return this.list.filter(item = item.checked).map(item = item.value)

}

}

AngularJS的数据双向绑定是怎么实现的

AngularJS的数据双向绑定的实现思路:$scope变量中使用脏检测来实现了数据双向绑定。

Scope作用:

通过数据共享连接Controller和View

事件的监听和响应

脏检测和数据绑定 双向数据绑定最经常的应用场景就是表单了,这样当用户在前端页面完成输入后,不用任何操作。

在该作用域内可以做到数据和视图的相互绑定,同时又能与其他$scope对象的作用域隔离开来。 当然,$scope也可以实现继承, 在一个controller里面的作用域可以继承它上一级的scope这样就不是独立存在了。

核心angular代码:

.module(‘mymodule’, []);

mymodule.controller(‘CartController’, [‘$scope’,

function CartController($scope) {

     // scope范围内的数据双向绑定

       $scope.items = [

           {name: “Angular应用”, quantity: 1, price: 199.00},

           {name: “Angular入门”, quantity: 1, price: 139.00},

           {name: “AngularJS权威教程”, quantity: 2, price: 84.20}

       ];

      //直接绑定事件remove

       $scope.remove = function (index) {

           $scope.items.splice(index, 1);

       }

   }

])

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/301511.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-30 16:09
下一篇 2024-12-30 16:09

相关推荐

  • Python数据统计案例的实现

    Python作为一个高级编程语言,拥有着丰富的数据处理库和工具,能够快速、高效地进行各类数据处理和分析。本文将结合实例,从多个方面详细阐述Python数据统计的实现。 一、数据读取…

    编程 2025-04-29
  • 如何实现图像粘贴到蒙版

    本文将从多个方面介绍图像粘贴到蒙版的实现方法。 一、创建蒙版 首先,在HTML中创建一个蒙版元素,用于接收要粘贴的图片。 <div id=”mask” style=”widt…

    编程 2025-04-29
  • Django ORM如何实现或的条件查询

    在我们使用Django进行数据库操作的时候,查询条件往往不止一个,一个好的查询语句需要考虑我们的查询要求以及业务场景。在实际工作中,我们经常需要使用或的条件进行查询,本文将详细介绍…

    编程 2025-04-29
  • Python一次性输入10个数如何实现?

    Python提供了多种方法进行输入,可以手动逐个输入,也可以一次性输入多个数。在需要输入大量数据时,一次性输入十个数就非常方便。下面我们从多个方面来讲解如何一次性输入10个数。 一…

    编程 2025-04-28
  • yarn npm 仓库用法介绍及使用案例

    本文将从多个方面对yarn npm仓库进行详细阐述,并为你提供一些实际使用案例。 一、npm和yarn的比较 npm和yarn都是JavaScript的包管理工具。npm在Java…

    编程 2025-04-27
  • 如何实现van-picker点击遮罩不关闭

    van-picker是一个非常实用的Vue组件,但默认情况下,点击遮罩会自动关闭选择器。本文将介绍如何通过代码实现van-picker点击遮罩不关闭的功能。 一、通过覆盖遮罩实现 …

    编程 2025-04-27
  • 如何实现矩阵相乘等于E

    本文将介绍如何通过代码实现两个矩阵相乘等于单位矩阵E。 一、线性代数基础 要理解矩阵相乘等于E,需要先了解一些线性代数基础知识。 首先,矩阵的乘法是满足结合律的,即(A*B)*C=…

    编程 2025-04-27
  • Python财务分析案例

    本文将以一个具体的案例为例,介绍如何使用Python进行财务分析。本文将从多个方面进行阐述。 一、数据收集和清洗 数据收集和清洗是财务分析的第一步。我们需要从不同数据源中收集数据,…

    编程 2025-04-27
  • Python项目案例:人脸识别

    人脸识别是指通过计算机对人脸图像进行分析,识别出人脸上的一些信息,如人脸的位置、大小、姿态、形状、以及其中的眼睛、鼻子、嘴巴等细节,对身份的识别具有重要的应用价值。 一、准备工作 …

    编程 2025-04-27
  • 如何实现一个随机抽数生成器

    随机数在程序开发中是非常常见的需求,而随机抽数生成器则是其一大应用场景。在这篇文章中,我们将从多个方面来探讨如何实现一个随机抽数生成器,包括随机数的概念、生成随机数的方法、如何抽取…

    编程 2025-04-27

发表回复

登录后才能评论