Vue3学习笔记(3.0)

本文介绍了Vue.js中的核心概念,如指令(如v-if、v-for、v-bind、v-on)及其参数、修饰符的使用,以及如何通过v-model实现双向数据绑定和事件监听来响应用户输入。

表达式会在当前活动实例的数据作用域下作为JavaScript被解析。有个限制就是,每个绑定就是,每个绑定只能包含单个表达式,所以下面的实例不会生效:

{{var a = 1}}  //语句,不是表达式


{{if (ok) {return message }}}   //控制流,不是三元表达式

指令

指令是带有v-前缀的特殊属性。

指令用于在表达式的值改变时,将某些行为应用到DOM上。如下例子:

<div id="app">
    <p v-if="seen">test文本</p>
</div>

<script>

const app1={
    data(){
        return{
            seen:true //若改成false,信息就无法显示
}}}

Vue.createApp(app1).mount('#app')
</script>

在该实例中,v-if指令将根据表达式seen的值(TRUE或false)来决定是否插入p元素

另外还有其他指令,每个都有特殊的功能。例如,v-for指令可以绑定数组的数据来渲染一个项目列表:

<!--
 * @Author: RealRoad1083425287@qq.com
 * @Date: 2023-03-26 16:26:51
 * @LastEditors: Mei
 * @LastEditTime: 2023-03-26 16:32:27
 * @FilePath: \vscode\v-for.html
 * @Description: 
 * 
 * Copyright (c) 2023 by ${git_name_email}, All Rights Reserved. 
-->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="vue_doc/vue.global3.js"></script>
</head>
<body>
    <div id="app">
        <ol>
            <li v-for="test in sites">
                {{test.city}}
            </li>

        </ol>
    </div>

    <script>
        const name={
            data(){
                return {
                    sites:[
                    {city:'sanghai'},
                    {city:"beijing"},
                    {city:"henan"}
                    ]
                }
            }
        }
        Vue.createApp(name).mount('#app')
    </script>
</body>
</html>

参数

参数在指令后以冒号指明。例如,v-bind指令被用来相应的更新HTML属性:

<div id="app">
    <p><a v-bind:href="url">测试文本</a></p>

</div>

<script>
const app={
data() {
return {
    url:'https://www.baidu.com'}}}


Vue.createApp(app).mount('#app')

</script>

在这里href是参数,告知v-bind指令将该元素的href属性与表达式url的值绑定。

另一个实例是v-on指令,它用于监听DOM事件:

<a v-on:click="doSomething"> ... </a>

<a @click="doSomething"> ... </a>

<a @[event]="doSomething"> ...</a>

在这里参数是监听的事件名。

修饰符

修饰符是以半角句号.指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。例如,.prevent修饰符告诉v-on指令对于触发的事件调用event.preventDefault():

<form v-on:submit.prevent="onSubmit"></form>

用户输入

在input输入框中我们可以使用v-model指令来实现双向数据绑定:

<!--
 * @Author: RealRoad1083425287@qq.com
 * @Date: 2023-03-26 16:57:44
 * @LastEditors: Mei
 * @LastEditTime: 2023-03-26 17:00:24
 * @FilePath: \vscode\数据绑定.html
 * @Description: 
 * 
 * Copyright (c) 2023 by ${git_name_email}, All Rights Reserved. 
-->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="vue_doc/vue.global3.js"></script>
</head>
<body>
    <div id="app">
        <p>{{message}}</p>
        <input v-model="message">
    </div>

    <script>
        const mez={
            data(){
                return {
                    message:"hello Mez!"
                }
            }
        }
        Vue.createApp(mez).mount('#app')
    </script>
</body>
</html>

 v-model指令用来在input、select、textarea、CheckBox、radio等表单控件元素上创建双向数据绑定,根据表单上的值,自动更新绑定的元素值。

按钮的时间我们可以使用v-on监听事件,并对用户的输入进行响应。

以下实例在用户电机按钮后对字符串进行反转操作:

<!--
 * @Author: RealRoad1083425287@qq.com
 * @Date: 2023-03-26 16:57:44
 * @LastEditors: Mei
 * @LastEditTime: 2023-03-26 17:13:54
 * @FilePath: \vscode\数据绑定.html
 * @Description: 
 * 
 * Copyright (c) 2023 by ${git_name_email}, All Rights Reserved. 
-->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="vue_doc/vue.global3.js"></script>
</head>
<body>
    <div id="app">
        <p>{{message}}</p>
        <!-- <input v-model="message"> -->
        <button v-on:click="reverseMessage">两级反转</button>
    </div>

    <script>
        const mez={
            data(){
                return {
                    message:'helloMez!'
                }
            },
            methods: {
                reverseMessage(){
                    this.message=this.message
                    .split('')
                    .reverse()
                    .join("")
                }
            }
        }
        Vue.createApp(mez).mount('#app')
    </script>
</body>
</html>

 

### 关于 Vue3 学习笔记 (尚硅谷 禹) Vue 是一种流行的前端框架,用于构建用户界面和单页应用程序。对于希望深入学习 Vue开发者来说,尚硅谷提供的课程是一个不错的选择[^1]。 #### Vue3 特性概述 Vue3 提供了许多新特性以及改进的功能,其中包括 Composition API 和新的生命周期钩子函数。以下是部分重要特性的总结: - **Composition API**: 这一功能允许开发者通过逻辑关注点来组织代码,而不是像 Options API 那样基于选项分组。它提高了代码的可重用性和维护性[^2]。 - **响应式系统的升级**: Vue3 使用 Proxy 对象替代了 Vue2 中的 Object.defineProperty 方法,从而提升了性能并支持深层次的对象检测。 - **Teleport 功能**: 它提供了一种机制,可以将组件的内容渲染到 DOM 结构中的任何位置,这对于模态框或者提示框非常有用。 - **Fragment 支持**: Vue3 允许一个模板中有多个根节点,这使得开发更加灵活。 #### 生命周期钩子的变化 在 Vue3 中引入了 Composition API 形式的生命周期钩子,这些钩子与 Vue2.x 中的传统钩子有一一对应的映射关系。例如 `onMounted` 替代了 `mounted`,这种变化有助于更清晰地表达业务逻辑。 ```javascript import { onMounted } from &#39;vue&#39;; export default { setup() { onMounted(() => { console.log(&#39;Component is mounted&#39;); }); } } ``` 以上代码展示了如何利用 Composition API 来定义挂载后的回调操作。 #### 推荐资源 如果想获取由尚硅谷张天禹老师讲解的具体内容,可以通过 B 站找到其发布的系列视频教程《Vue2.0 + Vue3.0全套教程》。此套教程不仅涵盖了基础概念还涉及到了实际项目应用案例分析。 另外需要注意的是,由于作者提到自己会随缘更新笔记,并且可能无法覆盖所有的理论细节,因此建议配合官方文档或其他权威书籍一起学习以获得全面的知识体系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mez_Blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值