VUE数据绑定方法

Vue 框架很核心的功能就是双向的数据绑定。 双向是指:HTML 标签数据 绑定到 Vue 对象,另外反方向数据也是绑定的。通俗点说就是,Vue 对象的改变会直接影响到 HTML 的标签的变化,而且标签的变化也会反过来影响 Vue 对象的属性的变化。
这样以来,就彻底变革了之前 Dom 的开发方式,之前 Dom 驱动的开发方式尤其是以 jQuery 为主的开发时代,都是 dom 变化后,触发 js 事件,然后在事件中通过 js 代码取得标签的变化,再跟后台进行交互,然后根据后台返回的结果再更新 HTML 标签,异常的繁琐。有了 Vue 这种双向绑定,让开发人员只需要关心 json 数据的变化即可,Vue 自动映射到 HTML 上,而且 HTML 的变化也会映射回 js 对象上,开发方式直接变革成了前端由数据驱动的 开发时代,远远抛弃了 Dom 开发主导的时代了。

一、Vue 绑定文本:

数据绑定最常见的形式就是使用 “Mustache” 语法(双大括号)的文本插值,比如模板引擎:handlebars 中就是用的{ {}}。创建的 Vue 对象中的 data 属性就是用来绑定数据到 HTML 的。如:

Message: {
    { msg }}

对于所有的数据绑定, Vue.js 都提供了完全的 JavaScript 表达式支持。

1、简单的拼接:

Message: {
    { msg + ' - ' + name }}
Hi - flydragon

2、计算、函数处理:

{
    { user.name=== '' ? '-' : user.name.subString(0,5) }}



  
  Vue入门之数据绑定-表达式运算
  


  
{ { msg + ' - ' + name }}

{ { isOk ? '123' : '456' }}

我的年龄是: { { age *2 }}

 

methods:{
   formatDate(dateTime) {
      if (!dateTime) return '';
      return parseTime(dateTime);
    },
}

 3、计算属性:

在做数据的绑定的时候,数据要进行处理之后才能展示到 html 页面上,虽然 vue 提供了非常好的表达式绑定的方法,但是只能应对低强度的需求。比如: 把一个日期按照规定格式进行输出,可能就需要我们对日期对象做一些格式化的出来,表达式可能就捉襟见肘了。Vue 对象提供的 computed 属性,可以让我们开发者在里面可以放置一些方法,协助我们绑定数据操作,这些方法可以跟 data 中的属性一样用,注意这些方法用的时候不要加()。 如:




  
  Vue入门之htmlraw
  


  
生日{ { getBirthday }}
年龄{ { age }}
地址{ { address }}

4、数据绑定过滤器:

{
    { message | filterA | filterB }}

在这个例子中,filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB 中。

过滤器是 JavaScript 函数,因此可以接收参数:

{
    { message | filterA('arg1', arg2) }}

这里,filterA 被定义为接收三个参数的过滤器函数。其中 message 的值作为第一个参数,普通字符串 'arg1'作为第二个参数,表达式 arg2 的值作为第三个参数。

 二、Vue 绑定html标签属性:

   Vue 中不能直接使用{ { expression }} 语法对 html 的标签属性进行绑定,而是用它特有的 v-bind 指令。语法结构:

<标签 v-bind:html标签属性名="要绑定的Vue对象的data里的属性名">

属性绑定简写:由于v-bind 使用非常频繁,所以 Vue 提供了简单的写法,可以去掉 v-bind 直接使用:即可。如

等价于

1、简单的属性绑定:

{
    { menuName }}



  
  Vue入门之数据绑定--属性绑定
  


  

  

2、布尔类型值用于属性绑定:标签的布尔类型的特性(属性),比如: disabled特性。这类属性特点只要存在就表示 truev-bind 应用于这类属性的时候,如果绑定值为真,则输出挣钱的对应属性。如果为假值,则不会渲染此特性。

如果 isButtonDisabled 的值是 nullundefined 或 false,则 disabled 特性甚至不会被包含在渲染出来的 

3、样式绑定:对于普通的属性的绑定,只能用上面的讲的绑定属性的方式。而 Vue 专门加强了 class 和 style 的属性的绑定。可以有复杂的对象绑定、数组绑定样式和类。:class = "{className1:条件1,className2:条件2}",其中,className可以加上'',也可以不加引号。

例1: 

绑定颜色类

例2: 

 结果:

例3:

结果:

例4:


 

 例5:删除某行页面上以中划线表示并字体标红:


              
            

例6:

 
{ { examDayMap[data.day].length + '个考试' }}
methods:{ getClassName(examCount) { if (examCount >= 5) { return 'red'; } else if ((examCount < 5) & (examCount >= 3)) { return 'orange'; } else if (examCount < 3) { return 'blue'; } } } .exam-calendar { margin-top: 5px; display: flex; justify-content: center; /* 水平方向 居中*/ align-items: center; /* 垂直方向 居中*/ color: #fff; background-color: #f1c98d; border-color: #f1c98d; border-radius: 15px; padding: 8px; cursor: pointer; } .red { background-color: red; border-color: red; } .blue { background-color: blue; border-color: blue; }

 

4、绑定样式数组:

data: {
  activeClass: 'active',
  errorClass: 'text-danger'
}

5、内联样式绑定:内联样式的绑定,非常类似于样式类的操作。v-bind:style 的对象语法十分直观——看着非常像 CSS ,其实它是一个 JavaScript 对象。 CSS 属性名可以用驼峰式(camelCase)或短横分隔命名(kebab-case)。v-bind:style会自动添加前缀,即当 v-bind:style 使用需要特定前缀的 CSS 属性时,如 transform ,Vue.js 会自动侦测并添加相应的前缀。




  
  Vue入门之htmlraw
  


  
vue 入门系列教程

5、数据绑定过滤器写法:


{
    { message | capitalize }}


 你可以在一个组件的选项中定义本地的过滤器

filters: {
  capitalize: function (value) {
    if (!value) return ''
    value = value.toString()
    return value.charAt(0).toUpperCase() + value.slice(1)
  }
}

或者在创建 Vue 实例之前全局定义过滤器:

Vue.filter('capitalize', function (value) {
  if (!value) return ''
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
})

new Vue({
  // ...
})

 

三、输出纯html:

由于 Vue 对于输出绑定的内容做了提前 encode,保障在绑定到页面上显示的时候不至于被 xss 攻击。但某些场景下,我们确保后台数据是安全的,那么我们就要在网页中显示原生的 HTML 标签。Vue 提供了v-html指令。

结果:

四、双向绑定:以上均为单向绑定。双向绑定指令为v-model:




  
  Vue入门之htmlraw
  


  

您输入的信息是:{ { msg }}

最终的结果就是:你改变 input 文本框的内容的时候,p 标签中的内容会跟着进行改变。

1、双向绑定的修饰符:

(1).lazy

在默认情况下,v-model 在每次 input 事件触发后将输入框的值与数据进行同步 (除了上述输入法组合文字时)。你可以添加 lazy 修饰符,从而转变为使用 change 事件进行同步:


(2).number

如果想自动将用户的输入值转为数值类型,可以给 v-model 添加 number 修饰符:

(3).trim:

如果要自动过滤用户输入的首尾空白字符,可以给 v-model 添加 trim 修饰符:

2、双向绑定案例:

(1)文本:

   1)单行文本:

Message is: { { message }}

    2)多行文本:

Multiline message is:

{ { message }}


   在文本区域插值 () 并不会生效,应用 v-model 来代替。

2、复选框:


Checked names: { { checkedNames }}

3、单选按钮:



Picked: { { picked }}

 4、选择框:

   1)单选:

Selected: { { selected }}

如果 v-model 表达式的初始值未能匹配任何选项,select 元素将被渲染为“未选中”状态。在 iOS 中,这会使用户无法选择第一个选项。因为这样的情况下,iOS 不会触发 change 事件。因此,更推荐像上面这样提供一个值为空的禁用选项。

下拉框值回显问题:需要值和类型一致,如:以下isMultipleProject=1,回显不了,因为isMultipleProject值为整形,而下拉框value值为字符型,


                  
                  
                

可以把下拉框值改成整形,:value表示整数型:

 
                  

 

  2)多选:绑定到数组


Selected: { { selected }}

3)远程搜索下拉:回显不需要加载列表,常用于下拉列表数据量较大的场景。


更多案例详见官网https://element.eleme.cn/#/zh-CN/component/installation

你可能感兴趣的:(VUE,js)