vue基础 组合式和响应式 模板语法 计算属性

news2025/1/17 9:05:02

模板语法 | Vue.js

根据文档

组合式和响应式

响应式

响应api单网页实例式

组合式

组合式api单网页实例

模板语法

文本插值 {{msg}}

最基本的数据绑定形式是文本插值,它使用的是“Mustache”语法 (即双大括号):

<script setup>
import {onMounted, ref, version} from 'vue'

const ver = ref('ok')  // ver = {value:'ok'}
const tt = () => {
  ver.value = new Date().toLocaleTimeString()
}
tt()
const mm = () => {
  setInterval(tt, 1000)
}
onMounted(mm)
</script>

<template>
  <p>{{ version }}</p>
  hello vue {{ ver }}
</template>
<style scoped></style>

Attribute 属性绑定

<h3 v-bind:align="align"></h3>

简写因为 v-bind 非常常用,我们提供了特定的简写语法:<h3 :id="ad"></h3>

<script setup>
import {ref} from 'vue'

const msg = ref('hello')
const ali = ref('center')
const ad = ref('box')
</script>

<template>
  <h3>{{ msg }}</h3>
  <h3 v-bind:align="ali">{{ msg }}</h3>
  <h3 v-bind:align="'right'">{{ msg }}</h3>
  <!-- 此标签的align属性和vue关系 -->
  <h3 align="center">{{ msg }}</h3>

  <!-- :id="'ad'"  相当于 id="ad" -->
  <h3 :align="ali" :id="'ad'">{{ msg }}</h3>
  <h3 :align="ali" v-bind:id="ad">{{ msg }}</h3>
</template>
<style scoped></style>

布尔型 Attribute

布尔型 attribute 依据 true / false 值来决定 attribute 是否应该存在于该元素上。disabled 就是最常见的例子之一。

v-bind 在这种场景下的行为略有不同:template

<button :disabled="isButtonDisabled">Button</button>

当 isButtonDisabled 为真值或一个空字符串 (即 <button disabled="">) 时,元素会包含这个 disabled attribute。而当其为其他假值时 attribute 将被忽略。

<script setup>
import {ref} from 'vue'

const isSubmit = ref(true)

function ok() {
  isSubmit.value = !isSubmit.value
}
</script>

<template>

  <button :disabled="isSubmit">{{ isSubmit ? '不可以提交' : '允许提交' }}</button>
  <br>
  <button :disabled="isSubmit">提交</button>
  <br>
  <button :disabled="false">提交</button>
  <br>
  <button>提交</button>
  <br>
  <button disabled>提交</button>
  <br>
  <a href="javascript:void(0)" @click="ok">{{ isSubmit ? '允许提交' : '不可以提交' }}</a>
</template>

<style scoped>
button {
  margin: 5px;
  border-radius: 8px;
  min-width: 55px;
  padding: 6px;
}
</style>

动态绑定多个值

如果你有像这样的一个包含多个 attribute 的 JavaScript 对象:js

const mm = ref({
  id: 100,
  class: 'ad',
  align: 'center'
})

通过不带参数的 v-bind,你可以将它们绑定到单个元素上:template

 <p v-bind="mm">ppppp</p>
  <!-- v-bind:属性简写 语法糖 :属性 :="对象" -->
  <p :="mm">ppppp</p>

使用 JavaScript 表达式

至此,我们仅在模板中绑定了一些简单的属性名。但是 Vue 实际上在所有的数据绑定中都支持完整的 JavaScript 表达式:template

 
 

{{ number + 1 }} {{ ok ? 'YES' : 'NO' }} {{ message.split('').reverse().join('') }} <div :id="`list-${id}`"></div>

这些表达式都会被作为 JavaScript ,以当前组件实例为作用域解析执行。

在 Vue 模板内,JavaScript 表达式可以被使用在如下场景上:

  • 在文本插值中 (双大括号)
  • 在任何 Vue 指令 (以 v- 开头的特殊 attribute) attribute 的值中
  • <script setup>
    import {ref} from 'vue'
    
    let pf = i => i * i
    let id = ref('ad')
    let msg = ref('hello world')
    </script>
    
    <template>
      <p>{{ 2 ** 3 }}</p>
      <p>{{ Math.random() > .5 ? 'yes' : 'no' }}</p>
      <p>{{ pf(6) }}</p>
      <p>{{ msg + 1}}</p>
      <p>{{ msg.split('').reverse().join('').toUpperCase().repeat(pf(3))}}</p>
      <p></p>
      <!-- id="list-ad" -->
      <p :id="`list-${id}`">:id="`list-${id}`"</p>
    
      <hr>
      <!-- 这是一个语句,而非表达式 -->
      <!--{{ var a = 1 }}-->
    
      <!-- 条件控制也不支持,请使用三元表达式 -->
      <!--{{ if (ok) { return message } }}-->
      <p></p>
      <p></p>
      <p></p>
    </template>

    a

调用函数

可以在绑定的表达式中使用一个组件暴露的方法:template

<script setup>
import {ref} from 'vue'
let date = ref(new Date())
let toTitleDate = d => {
  return d.getTime()
}

function formatDate(date) {
  let yy = date.getFullYear()
  let mm = date.getMonth() + 1
  let dd = date.getDate()
  return `${yy}年${mm}月${dd}日`
}
</script>
<template>
  <time :title="toTitleDate(date)" v-bind:datetime="date">
    {{ formatDate(date) }}
  </time>
</template>
<style scoped></style>

动态参数

--注意,参数表达式有一些约束,
参见下面“动态参数值的限制”与“动态参数语法的限制”章节的解释
 

<script setup>
import {ref} from 'vue'
let n = 'align'
let v = 'right'
</script>
<template>
  <div v-bind:[n]="v" >动态参数绑定</div>
</template>
<style scoped></style>

计算属性

计算属性是循环的方法,通过computed(fn) 来实现自动响应式,此函数必须返回一个值

<script setup>
import {reactive,computed} from 'vue'

const author = reactive({
  name: 'John Doe',
  books: [
    'Vue 2 - Advanced Guide',
    'Vue 3 - Basic Guide',
    'Vue 4 - The Mystery'
  ]
})

//计算属性 是响应式 使用时 在template {{aa}}
const aa = computed(()=>{
  console.log("aa计算属性")
  return author.books.length>0 ? 'Yes' :'No'
})
//函数 {{ok()}}
function ok(){
  let t = 'No'
  if(author.books.length>0) t = 'Yes'
  console.log("ok()调用函数")
  return t
}
</script>
<template>
  <p>Has published books:</p>
  <span>{{ author.books.length > 0 ? 'Yes' : 'No' }}</span>
  <!-- 调用函数 -->
  <p>{{ok()}}</p>
  <!-- 计算属性 表达式 -->
  <p>{{aa}}</p>
</template>
<style scoped></style>

Class 与 Style 绑定

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Promethues(五)查询-PromQL 语言-保证易懂好学

一、介绍 普罗米修斯提供了一种称为PromQL&#xff08;普罗米修斯查询语言&#xff09;的函数式查询语言&#xff0c;允许用户实时选择和聚合时间序列数据。 表达式的结果可以显示为图形&#xff0c;在 Prometheus 的表达式浏览器中显示为表格数据&#xff0c;也可以通过 HTT…

EMQX的docker部署与使用(mqtt)

1&#xff1a;先创建一个挂载emqx的目录 2&#xff1a;docker拉去emqx docker pull emqx/emqx:latest2-1&#xff1a;先启动一次eqmx&#xff0c;然后停止&#xff0c;删除容器 docker run -d --name emqx --privilegedtrue -p 1883:1883 -p 8883:8883 -p 8083:8083 -p 8084…

Spring Bean生命周期图扩展接口介绍spring的简化配置

目录 1. 生命周期简图 2. 扩展接口介绍 2.1 Aware接口 2.2 BeanPostProcessor接口 2.3 InitializingBean 2.4 DisposableBean 2.5 BeanFactoryPostProcessor接口 3. spring的简化配置 3.1 项目搭建 3.2 Bean的配置和值注入 3.3 AOP的示例 1. 生命周期简图 2. 扩展接…

Mobileye CEO来华:只有能控制住成本的公司,才能活下来

‍作者|德新 编辑|王博 上午9点近一刻&#xff0c;Mobileye CEO Amnon Shuashua步入酒店的会议室。由于Amnon本人是以色列希伯来大学的计算机科学教授&#xff0c;大部分人更习惯称他为「教授」。 时近以色列的新年&#xff0c;这趟教授的中国之行安排十分紧凑。 他率领了一…

IP地址在各行业中的应用场景

1、互联网交易、支付反欺诈 通过分析IP应用场景、IP地址的出现位置的离散程度、分布情况综合用户行为及时间判断IP地址风险程度&#xff0c;过滤机器流量。在登陆、交易、支付等多个环节结合多重验证等技术减少欺诈行为。 2、P2P平台反“羊毛党” 通过分析IP应用场景、位置信…

得帆云“智改数转,非同帆响”-AIGC+低代码PaaS平台系列白皮书,正式发布!

5月16日下午&#xff0c;由上海得帆信息技术有限公司编写&#xff0c;上海市工业互联网协会指导的以“智改数转&#xff0c;非同帆响”为主题的《得帆云 AIGC低代码PaaS平台系列白皮书》正式在徐汇西岸国际人工智能中心发布。 本次发布会受到了上海市徐汇区政府、各大媒体和业内…

c刷题(四)

获得月份天数 获得月份天数_牛客题霸_牛客网 这道题可以用switch case语句解&#xff0c;不过这道题更简单的方法是数组&#xff0c;关键点在于判断是否为闰年。 #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include<assert.h> int year_run(int n) …

Go 异常处理

代码在执行的过程中可能因为一些逻辑上的问题而出现错误 func test1(a, b int) int {result : a / breturn result } func main() {resut : test1(10, 0)fmt.Println(resut) }panic: runtime error: integer divide by zero goroutine 1 [running]: …

【数据库】数据库系统概论(一)— 概念

theme: qklhk-chocolate 基本概念 数据 描述事物的符号记录称为数据。 记录时是计算机中表示和存储数据的一种格式或一种方法。 数据库 数据库是长期存储在计算机内、有组织、可共享的大量数据的集合。 数据库中的数据按一定的数据模型组织、描述和储存。具有较小冗余度…

我的创作纪念日(第1024天)

机缘 当我开始在CSDN上创作时&#xff0c;我的初心主要是出于对技术的热爱和对知识分享的渴望。我一直以来都对计算机科学和技术领域充满兴趣&#xff0c;并且热衷于学习和探索新的技术知识和应用。通过在CSDN上发表文章和分享我的经验和见解&#xff0c;我希望能够与更多的技…

基于webman的CMS,企业官网通用PHP后台管理系统

2023年9月11日10:47:00 仓库地址&#xff1a; https://gitee.com/open-php/zx-webman-website 还有laravelscui的版本目前还未开源&#xff0c;电商laravel版本差不多&#xff0c;后续在移植webman 算是比较标准的phpvue的项目 CMS&#xff0c;企业官网通用PHP后台管理系统 …

UE5 Foliage地形植被实例删不掉选不中问题

目前问题测试发生在5.2.1上 地形上先填充后刷的植被删不掉 首先这个就是bug&#xff0c;大概看到说是5.3上能解决了&#xff0c;对此我只能吐槽ue5上地形植被bug太多了 什么nanite还能产生bug&#xff0c;不过这次又不是&#xff0c;整个删掉instance可以删除所有植被&#…

C++项目实战——基于多设计模式下的同步异步日志系统-⑨-同步日志器类与日志器建造者类设计

文章目录 专栏导读Logger类设计同步日志器类设计同步日志器测试日志器建造者模式设计抽象日志器建造者类派生局部日志器建造者日志器建造者类测试 同步日志器类与日志器建造者类整理 专栏导读 &#x1f338;作者简介&#xff1a;花想云 &#xff0c;在读本科生一枚&#xff0c;…

将阿里云盘挂载到本地磁盘-CloudDrive工具使用教程

CloudDrive是什么&#xff1f; 支持将115、沃家云盘、天翼云盘、阿里云盘、WebDAV挂载到本地并创建本地磁盘。 CloudDrive是一个全方位的云存储管理平台&#xff0c;旨在无缝集成多个云存储服务&#xff0c;将它们统一整合到一个界面中。 使用CloudDrive&#xff0c;您可以轻松…

Python 图形化界面基础篇:监听按钮点击事件

Python 图形化界面基础篇&#xff1a;监听按钮点击事件 引言 Tkinter 库简介步骤1&#xff1a;导入 Tkinter 模块步骤2&#xff1a;创建 Tkinter 窗口步骤3&#xff1a;创建按钮和定义事件处理函数步骤4&#xff1a;创建显示文本的标签步骤5&#xff1a;启动 Tkinter 主事件循环…

杂牌行车记录仪删除后覆盖恢复案例

行车记录仪从一开始的新鲜设备&#xff0c;到现在汽车必备&#xff0c;有的厂商甚至直接出厂就带了行车记录仪&#xff0c;正因为如此重要所以市场上充斥着很多记录仪品牌。下边我们来看看这个杂牌的记录仪恢复案例。 故障存储:8G microSD卡 故障现象: 8G算是小卡&#xff0…

pta java版

7-1 厘米换算英尺英寸 如果已知英制长度的英尺foot和英寸inch的值&#xff0c;那么对应的米是(footinch/12)0.3048。现在&#xff0c;如果用户输入的是厘米数&#xff0c;那么对应英制长度的英尺和英寸是多少呢&#xff1f;别忘了1英尺等于12英寸。 思路&#xff1a; 1英尺12英…

将近 5 万字讲解 Java Web / Servlet 网络编程超级详细概念原理知识点

1. Web 基本概念 首先 Web 网页 / 网站的意思&#xff08;例如&#xff1a;百度 www.baidu.com&#xff09; Web 分类&#xff1a;静态 Web / 动态 Web&#xff08;技术栈 Servlet / JSP、ASP、PHP&#xff09; 动态 web 在 java 中叫 javaweb BS (Browser / Server&#xff…

伙伴云连续2年入选Gartner《中国分析平台市场指南》,数据分析能力遥遥领先

伙伴云作为中国分析与商业智能平台代表性厂商&#xff0c;因出色的数据分析能力&#xff0c;入选Gartner2023《中国分析平台市场指南》&#xff08;《Market Guide for Analytics Platforms, China》&#xff0c;以下简称“指南”&#xff09;&#xff0c;成为入选该报告中唯一…

内外统一的边缘原生云基础设施架构——火山引擎边缘云

近日&#xff0c;火山引擎边缘云边缘计算架构师郭少巍在LiveVideoStack Con 2023上海站围绕火山引擎边缘云海量分布式节点和上百T带宽&#xff0c;结合边缘计算在云基础设施架构方面带来的挑战&#xff0c;分享了面对海量数据新的应用形态对低时延和分布式架构的需求&#xff0…