首页 > 其他分享 >【Vue】大悟!模板语法-插值语法&指令语法

【Vue】大悟!模板语法-插值语法&指令语法

时间:2023-09-15 12:04:33浏览次数:42  
标签:Vue name 插值 绑定 语法 data 属性

Vue系列持续更新

模板语法

Vue模板语法包括两大类

  1. 插值语法

插值语法也就是两个大括号,也叫Mustache

功能:用于解析标签体内容,可以进行运算、三元表达式等,将最终解析出来的内容插入到标签中

写法:{{xxx}},xxx 是 js 表达式,可以直接读取到 data 中的所有区域

  • 插值表达式中只能放置单个表达式,不支持语句块、循环、条件语句等
  • 插值表达式中的内容会被解释为JS 表达式,因此你可以在其中执行基本的JS 运算、函数调用和条件判断等
  • 如果需要更复杂的逻辑,应该使用计算属性、方法或者指令来实现--后面会讲到
  • 在插值表达式中,你直接使用属性名(无需 this),Vue.js 会自动识别并将表达式与 Vue 实例的数据进行绑定因为 Vue 在模板编译过程中会自动处理这些细节
  1. 指令语法

功能:用于解析标签(包括:标签属性、标签体内容、绑定事件…)

举例:<a v-bind:href="xxx">或简写为<a :href="xxx">,xxx 同样要写 js 表达式,可以直接读取到 data 中的所有属性

备注:Vue中有很多的指令,且形式都是 v-xxx,此处只是拿v-bind举例

代码

<div id="root">
   <!-- 普通写法 -->
   <!-- 单向数据绑定:<input type="text" v-bind:value="name"><br/>
   双向数据绑定:<input type="text" v-model:value="name"><br/> -->

   <!-- 简写 -->
   单向数据绑定:<input type="text" :value="name"><br/>
   双向数据绑定:<input type="text" v-model="name"><br/>

   <!--v-model只能应用在表单类元素(输入类元素)上 -->
   <!-- <h2 v-model:x="name">错了</h2> -->
  </div>
 </body>

 <script type="text/JS">
  Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示

  new Vue({
   el:'#root',
   data:{
    name:'即兴小索奇'
   }
  })
 </script>

拓展

  • vue中的指令都是v-开头
  • 输出vue实例时,f12查看,里面带$ 符号的,都是给我们用的,下划线_结尾的是vue底层用的,不是给我们用的
  • 函数都会有 prototype ,除了 Function.prototype.bind() 之外
  • 对象都会有 __proto__ ,除了 Object.prototype 之外(其实它也是有的,之不过是 null
  • 所有函数都由 Function 创建而来,也就是说他们的 __proto__ 都等于 Function.prototype
  • Function.prototype 等于 Function.__proto__

具体来说vue示例

  • _ 开头的表示 Vue 内部属性,如 _isVue_uid 等,不要直接操作改属性
  • $ 开头的表示 Vue 添加的实例属性/方法,如 refs、emit 等(可以直接vue.$调用哈)
  • 粉红色的是响应式属性,即和模板绑定的数据,在 datacomputed 等中定义,可以直接修改它们触发响应式更新
  • 普通的black色属性是用户可能额外定义的普通属性,不是响应式的

所以在打印 Vue 实例时,根据不同符号可以区分属性的作用,这可以帮助我们更好地理解和使用 Vue需要注意只有 data 中的数据和 computed 是响应式的

JS 中没有类的概念的,主要通过原型链来实现继承通常情况下,继承意味着复制操作,但在 JS中 默认并不会复制对象的属性,相反,JS 只是在两个对象之间创建一个关联(原型对象指针),这样,可以简单理解为委托(继承),一个对象就可以通过委托访问另一个对象的属性和函数,所以与其叫继承,委托的说法反而更准确些

当要找一个自己对象原型上没有的属性或者方法的时候,会沿着原型链一级一级的往上走 s1===>s1.__proto__==>s1.__proto__.__proto__==>s1.__proto__.__proto__.__proto__==>null

const c = new Vue({
   el:'#root',
   data:{
    name:'即兴小索奇'
   }
  })
        console.log(c);

图中的name是数据代理(后期会讲到-简单理解就是修改能变化的数据)

【Vue】大悟!模板语法-插值语法&指令语法_Vue

image-20230807012433413

【Vue】大悟!模板语法-插值语法&指令语法_Vue_02

image-20230807013614066

插值语法

<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8" />
  <title>模板语法</title>
  <!-- 引入Vue -->
  <script type="text/JS" src="../js/vue.js"></script>
 </head>
 <body>
  <div id="root">
   <h1>插值语法</h1>
   <h3>你好,{{name}}</h3>
   <hr/>
   <h1>指令语法</h1>
   <a v-bind:href="school.url.toUpperCase()" x="hello">点我去{{school.name}}学习1</a>
   <a :href="school.url" x="hello">点我去{{school.name}}学习2</a>
  </div>
 </body>

 <script type="text/JS">
  Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示

  new Vue({
   el:'#root',
   data:{
    name:'jack',
    school:{
     name:'suoqi-teacher,
     url:'https://github.com/suoqi',
    }
   }
  })
 </script>
</html>

【Vue】大悟!模板语法-插值语法&指令语法_插值_03

image.png

数据绑定

Vue中有2种数据绑定的方式

  • v-bind:单向绑定,数据只能从 data 流向页面
  • v-model:双向绑定,data和页面互通,改任意一方都可变化

备注

  • v-model:双向绑定一般都应用在表单类元素上,如 <input>``<select>``<textarea>等,如标题使用就会报错,因为这样的设计考虑到了页面双向的影响(如标题没有value输入,怎么影响data变化?没有意义了)
  • v-model:value可以简写为v-model,因为v-model默认收集的就是value值
  • v-bind:value 可以简写为:value

代码

<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8" />
  <title>数据绑定</title>
  <!-- 引入Vue -->
  <script type="text/JS" src="../js/vue.js"></script>
 </head>
 <body>

  <!-- 准备好一个容器-->
  <div id="root">
  
   单向数据绑定:<input type="text" :value="name"><br/>
   双向数据绑定:<input type="text" v-model="name"><br/>

   <!-- 如下代码是错误的,因为v-model只能应用在表单类元素(输入类元素)上 -->
   <!-- <h2 v-model:x="name">hello</h2> -->
  </div>
 </body>

 <script type="text/JS">
  Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示

  new Vue({
   el:'#root',
   // data中的属性名也可加引号,但常常不加引号
   data:{
    name:'即兴小索奇'
   }
  })
 </script>
</html>

【Vue】大悟!模板语法-插值语法&指令语法_Vue_04

image-20230807005208611

注意

在插值中{{method()}}{{method}}完全不同

  • 前者是把方法的返回值插入
  • 后者完全是函数插值

对您有用的话请点个免费的爱心叭~

标签:Vue,name,插值,绑定,语法,data,属性
From: https://blog.51cto.com/u_16088329/7479642

相关文章

  • uniapp VUE-H5页面微信公众号内使用微信JSAPI支付
    注意看本文主要讲解uniapp打包成h5页面并部署在公众号时使用JSAPI的微信支付问题前期准备工作.首先要有一个开通商户注册的公众号,我们需要他的appid;.其次要开通商户公众号的公众号支付的功能并添加域名,开通完成后就可以基本开始我们的开发了既然是jsapi开发自然是要引入的......
  • Vue的快速上手
    01-Vue介绍0前端的发展史1.HTML(5)、CSS(3)、JavaScript(ES5、ES6):编写一个个的页面->给后端(PHP、Python、Go、Java)->后端嵌入模板语法->后端渲染完数据->返回数据给前端->在浏览器中查看2.Ajax的出现->后台发送异步请求,Render+Ajax混合3.单用Ajax(加载数据,DOM......
  • Vue-选择器v-model绑定对象
    Vue-选择器v-model绑定对象<template><el-selectv-model="value"placeholder="请选择"><el-optionv-for="iteminoptions":key="item.value":label="item.label":value=&quo......
  • Vue--this的指代问题及用法
    Vue--this的指代问题及用法this在普通函数(function(){})里,指代调用该函数(方法)的对象this在箭头函数(()=>{})里,指代定义该箭头函数的外层对象在axios调用当前vue实例的data:axios回调函数(.then())是在执行栈中被执行,其中this指向window,若要在axios中取后端数据并......
  • vue2.0 表单验证明明有值却提示错误
    明明有值却总是提示为空我的解决方法时将number转为字符串验证方法如图:(验证只可以输入数字)赋值时转为字符串: ......
  • 【php基础】基础语法01
    一、PHP简述PHP(全称:PHP:HypertextPreprocessor,即"PHP:超文本预处理器")是一种通用开源脚本语言。在一个php文件中可以包括以下内容:PHP文件可包含文本、HTML、JavaScript代码和PHP代码PHP代码在服务器上执行,结果以纯HTML形式返回给浏览器PHP文件的默认文件扩展名是".php"......
  • 一个基于Vue模型的表单生成器
    哈喽,我是老鱼,一名致力于在技术道路上的终身学习者、实践者、分享者!VuetifyFormBase是一个基于模型的表单生成器,目的是提供一个工具,以便以较少的努力从任何模型数据生成可编辑的表单,即使模型是一个深度嵌套的对象。VuetifyFormBase作为Vue组件工作,可以很容易地集成到任何VU......
  • Hbaseshell命令中的一些语法
    help‘xx’看库list_namespace看表list建表create't1','f1'写数据put't1','r1','c1:name','value'读数据一行get't1','r1'get't1','r1',{COLUMN=>['r1:name',&......
  • 10个在线检验英语语法的网站
    10个在线检验英语语法的网站 10个在线检验英语语法的网站。推荐10个具有英文检查&修改功能的网站,帮助参加各种英语能力考试的考生更加有方向和针对性的学习和攻克语法。  1.NOUNPLUS:https://www.nounplus.net/grammarcheck/nounplus是一个免费的语法检查......
  • Vue介绍
    前端的发展史1HTML(5)、CSS(3)、JavaScript(ES5、ES6、ES11):编写一个个的页面->给后端(PHP、Python、Go、Java)->后端嵌入模板语法->后端渲染完数据->返回数据给前端->在浏览器中查看2Ajax的出现->后台发送异步请求,Render+Ajax混合3单用Ajax(加载数据,DOM渲染页面......