【vue.js】文档解读【day 1】 | 模板语法2

在这里插入图片描述

如果阅读有疑问的话,欢迎评论或私信!!
本人会很热心的阐述自己的想法!谢谢!!!

文章目录

  • 模板语法
    • JavaScript表达式
      • 仅支持表达式
      • 调用函数?
      • 受限的全局访问
    • 指令
      • 参数
      • 动态参数
        • 动态参数中 值 的限制
        • 动态参数中 语法 的限制

模板语法

JavaScript表达式

除了前面的文本插值绑定attr属性外,我们还可以直接在Vue中输入JavaScript表达式。就像下面这样:

{{ message.split('').reverse().join('') }}

仅支持表达式

但是有一个很重要的点,就是并非所有语句都可以,官方文档中说明声明语句条件控制语句都不行,并且给了一个非常简单的测试方法:在{{}}中输入return + 你要使用的JavaScript表达式,如果没有报红(也就是合法)的情况下,你就可以使用。就像下面这样:

 <p>{{ return ok ? 'YES' : 'NO' }}</p>

该代码并没有报红,在删除return之后就可以运行!

JavaScript通常用于以下两种场景:

  • {{ }}中
  • v-attr属性的值中,例如::src=" ok ? 'YES' : 'NO'"

调用函数?

受限的全局访问

在上面讲到的JavaScript支持的表达式中,我们在访问变量时,能够访问的变量通常是有限的。官方文档中提供了能够访问到的全局对象列表,同时也提供了一个自行添加全局变量的方法:

main.js

//从vue中获取createApp方法
import { createApp } from "vue";
//引入组件
import App from "./App.vue";
//使用createApp方法创建vue实例
const app = createApp(App);
//在挂载前设置全局对象
app.config.globalProperties.myName = "Jing";
//将vue实例挂载在id=app的元素上。
app.mount("#app");

App.vue

<template>
 <p>{{ myName  }}</p>
</template>

tips:注意扩展全局对象要在挂载前设置,否则会收到vue的提示,并且无法使用该全局对象。

runtime-core.esm-bundler.js:47 [Vue warn]: Property “myName” was accessed during render but is not defined on instance.
at

指令

通过上面的学习,我们知道了vue中v-bind、v-html的使用方法。除此之外,vue提供了许多v-前缀的内置指令,这些只是一些vue提供的API,我们要通过文档了解其中的原理,就一直继续学习吧!

一个指令的任务就是可以在表达式的值变化时可以响应式的更新dom。例如文档中v-if的例子:

<p v-if="seen">Now you see me</p>

这里的v-if会根据seen的值响应式更新这个p标签

参数

在前面使用v-bind时,我们设置了HTML标签中的src、disabled属性,该属性位于v-bind:的后面。这些属性其实就是v-bind的参数,回顾一下:

<template>
 <img :src=imgSrc >
 <button :disabled = disableEmpty>123</button>
 <p>{{ myName  }}</p>
</template>

<script>
  export default{
    data(){
      var imgSrc = "/src/components/icons/newImg.gif";
      var disableEmpty = "";
      return {
        imgSrc,
        disableEmpty
      }
    }
  }
</script>

另外一个例子就是v-on,这个指令的任务是监听DOM时间,然后做出一些事情:

  <p v-on:click="console.log(1)" >{{ myName }}</p>

点击这个p标签时控制台会输出1。该指令也有一个语法糖:使用@表示v-on指令

动态参数

在学习动态参数时,回想以下JavaScript中对象的属性名表示有两个方法:

  • 通过obj.attribute访问对象的属性
  • 通过obj[attribute]访问对象的属性

其中第二种可以动态的访问对象的属性,也就是attribute可以是变量名。

在vue中同样可以动态的绑定指令的参数,和JavaScript类似,需要使用[ ]格式,例如:

<img :[orderSrc]="imgSrc" />

<script>
export default {
  data() {
    var orderSrc = "src"
    return {
      orderSrc
    };
  },
};
</script>

上述代码中,orderSrc是动态参数,在vue实例中动态设置为src。

同样的,你也可以对一个事件名称使用动态参数,就像这样:

 <p @[orderClick]="console.log(1)" >{{ myName }}</p>

<script>
export default {
  data() {
    var orderClick = "click"
    return {
      orderClick
    };
  },
};
</script>

在这个代码中,orderClick可以是click focus mouseover等事件名称,具体使用参照自己的项目随机应变!

动态参数中 值 的限制

动态参数中表达式的值只能是一个字符串,或者是null,当值为null时意味这在该DOM中移除监听事件。

动态参数中 语法 的限制

动态参数中的表达式有一些语法限制,比如空格和引号等符号都是不合法的,例如官方文档中的一段示例代码:

<a :['foo' + bar]="value"> ... </a>

该代码中存在引号,不会通过编译器编译,而如果我们项目中确实需要这样的代码,我们可以使用vue中的计算属性(computed)来替换复杂的表达式。计算属性在后面将会解释。

同时,需要注意的是,在前文vue起步中的DOM 中的根组件模板板块,我们知道一种不使用vue组件,而是使用HTML文件里的模板,忘记的话可以移步至vue起步博文中回顾。在这种情况下,我们要避免使用大写字母,因为浏览器会把他强制转换为小写,例如下面这个代码:

<a :[someAttr]="value"> ... </a>

该代码中someAttr会被转换为someattr,而如果我们的vue实例中没有someattr这个属性,那么这段代码将无法正常工作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/430647.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode Python - 31.下一个排列

目录 题目答案运行结果 题目 整数数组的一个 排列 就是将其所有成员以序列或线性顺序排列。 例如&#xff0c;arr [1,2,3] &#xff0c;以下这些都可以视作 arr 的排列&#xff1a;[1,2,3]、[1,3,2]、[3,1,2]、[2,3,1] 。 整数数组的 下一个排列 是指其整数的下一个字典序更…

C语言-两数组元素互换

#include <stdio.h> #include <string.h>//两数组元素互换 void swap(int ch1[],int ch2[],int sz) {int i 0;char ch 0;for(i 0;i < sz;i){ch ch1[i];ch1[i] ch2[i];ch2[i] ch;} } //打印数组元素 void print(int ch[],int sz) {int i 0;for(i 0;i <…

04. Nginx入门-Nginx WEB模块

测试环境 此处使用的yum安装的Nginx路径。 此处域名均在本地配置hosts。 主配置文件 路径&#xff1a;/etc/nginx/nginx.conf user nginx; worker_processes auto;error_log /var/log/nginx/error.log notice; pid /var/run/nginx.pid;events {worker_connection…

Linux——自写一个简易的shell

目录 前言 一、打印提示信息 二、分割字符串 三、替换程序 前言 之前学习了很多进程相关的知识&#xff0c;包括环境变量、进程的创建与退出、进程等待、进程替换。现在可以用所学的作一个小总结&#xff0c;手撕一个shell解释器&#xff0c;大致的思路是先通过环境变量获…

【会议征稿通知】第二届数字化经济与管理科学国际学术会议(CDEMS 2024)

第二届数字化经济与管理科学国际学术会议&#xff08;CDEMS 2024&#xff09; 2024 2nd International Conference on Digital Economy and Management Science&#xff08;CDEMS 2024&#xff09; 2024年第二届数字经济与管理科学国际会议(CDEMS 2024) 定于2023年4月26-28日…

【Sql Server】存储过程的创建和使用事务,常见运用场景,以及目前现状

欢迎来到《小5讲堂》&#xff0c;大家好&#xff0c;我是全栈小5。 这是《Sql Server》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解&#xff0c; 特别是针对知识点的概念进行叙说&#xff0c;大部分文章将会对这些概念进行实际例子验证&#xff0c;以此达到加深对…

IPSEC---VPN

文章目录 目录 文章目录 一.TCP/IP 协议的缺点 二.IPsec诞生背景 IPsec可提供安全服务 三.IPsec协议簇 IPsec的两种工作模式 传输模式 隧道模式&#xff1a; IPsec的安全协议 AH 协议:鉴别头协议 ESP协议&#xff1a;封装安全载荷协议 AH与ESP对比 AHESP报文&#xff1a…

【笔记】【电子科大 离散数学】 3.谓词逻辑

谓词引入 因为含变量的语句&#xff08;例如x > 3&#xff09;不是命题&#xff0c;无法进行逻辑推理。 为了研究简单命题句子内部的逻辑关系&#xff0c;我们需要对简单命题进行分解&#xff0c;利用个体词&#xff0c;谓词和量词来描述它们&#xff0c;并研究个体与总体…

透明玻璃屏幕为什么那么贵

透明玻璃屏幕之所以价格较高&#xff0c;主要是由于以下几个方面的原因&#xff1a; 技术研发与创新&#xff1a;透明玻璃屏幕作为一种先进的显示技术&#xff0c;其研发和制造过程涉及到许多复杂的技术。这些技术的研发和创新需要投入大量的资金和时间。此外&#xff0c;透明玻…

推理判断01-程永乐-图形1

课程安排 出题形式 图形推理 1、位置规律 图形题目

供应商为啥要入驻政采网

供应商入驻政采网的原因主要有以下几点&#xff1a; 扩大企业知名度和商业机会&#xff1a;通过在政采网上的展示&#xff0c;可以让更多的政府机关、事业单位等了解企业的品牌和商品&#xff0c;提高企业的知名度&#xff0c;同时也会吸引更多的潜在客户&#xff0c;增加商业…

分布式数字身份:通往Web3.0世界的个人钥匙

数字化时代&#xff0c;个人身份已不再仅仅局限于传统形式&#xff0c;分布式数字身份&#xff08;Decentralized Identity&#xff0c;简称DID&#xff09;正崭露头角&#xff0c;它允许个人通过数字签名等加密技术&#xff0c;完全掌握和控制自己的身份信息。研究报告显示&am…

Chatgpt4.0国内使用网站公开。免费的都是假的。

Chatgpt简介 ChatGPT&#xff0c;这个名字自2022年底以来&#xff0c;在全球范围内引起了广泛的关注和讨论。它是由OpenAI公司开发的一款基于人工智能技术的语言模型&#xff0c;拥有惊人的自然语言处理和生成能力。ChatGPT不仅可以理解人类的语言&#xff0c;还能以类似人类的…

一本书讲透ChatGPT,实现从理论到实践的跨越!大模型技术工程师必读书籍【送书活动】

目录 前言一、内容简介二、作者简介三、专家推荐四、读者对象五、目录福利总结 前言 OpenAI 在 2022 年 11 月推出了人工智能聊天应用—ChatGPT。它具有广泛的应用场景&#xff0c;在多项专业和学术基准测试中表现出的智力水平&#xff0c;不仅接近甚至有时超越了人类的平均水平…

怎么将照片无损放大?三种简单方法分享

在数字影像领域&#xff0c;我们常常遇到需要放大图片却担心失真的困扰。如何在放大图片的同时保持清晰度和细节&#xff1f;让我们一起来探索三款强大的图片无损放大软件&#xff0c;助你轻松处理各种放大需求&#xff0c;释放画面细节&#xff0c;呈现令人惊喜的视觉效果&…

代码学习记录12

随想录日记part12 t i m e &#xff1a; time&#xff1a; time&#xff1a; 2024.03.05 主要内容&#xff1a;今天的主要内容是了解二叉树的理论基础&#xff0c;并且熟练掌握如何递归和迭代遍历二叉树。 理论基础递归遍历迭代遍历统一迭代 Topic1二叉树理论基础 1.二叉树的题…

ubuntu20.04设置docker容器开机自启动

ubuntu20.04设置docker容器开机自启动 1 docker自动启动2 容器设置自动启动3 容器自启动失败处理 1 docker自动启动 &#xff08;1&#xff09;查看已启动的服务 $ sudo systemctl list-units --typeservice此命令会列出所有当前加载的服务单元。默认情况下&#xff0c;此命令…

【QT】窗口的大小标题图标设置

窗口的大小标题图标设置 添加一个新的类 创建完成&#xff0c;根据上一节最后的在总结&#xff0c;做个测试&#xff1a; #include "mybutton.h" #include <QDebug>//打印&#xff0c;标准输出 MyButton::MyButton(QWidget *parent) : QPushButton(parent) { …

基于springboot的新闻推荐系统论文

基于springbootvue的新闻推荐系统 摘要 随着信息互联网购物的飞速发展&#xff0c;国内放开了自媒体的政策&#xff0c;一般企业都开始开发属于自己内容分发平台的网站。本文介绍了新闻推荐系统的开发全过程。通过分析企业对于新闻推荐系统的需求&#xff0c;创建了一个计算机…

09. Nginx进阶-Rewrite

简介 什么是rewrite&#xff1f; rewrite即URL重写&#xff0c;主要实现URL地址重写&#xff0c;以及重定向。 就是把插入web的请求重定向到其他URL的过程。 rewrite使用场景 URL地址调整 例如用户访问wang.mingqu.com将其跳转到ming.mingqu.com。 或者当用户通过http的方…