vue基础内容总结(二)

Vue.js是一个用于构建用户界面的渐进式框架,核心库专注于视图层,易于整合与第三方库或现有项目。本文介绍了Vue.js的基础概念,包括声明式渲染、条件与循环、用户输入处理等关键特性。

vue.js是什么?

    Vue (读音 /vjuː/,类似于 view)是一套用户构建用户界面的渐进式框架。与其他框架不同的是,vue被设计为可以自底向上逐层应用。Vue的核心库只关心图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue也完全能够为复杂的单页应用提供驱动。

声明式渲染

    Vue.js 的核心是一个允许采用简洁的模板语法来声明式的将数据渲染进DOM的系统,最基础的内容如下:

    这样,我们已经成功创建了第一个vue应用,看起来这跟渲染一个字符串模板非常相似,但是vue在背后做了大量的工作。现在数据和DOM已经建立了关联,所有的东西都是响应式的。我们要怎么确认呢?打开你的浏览器的JavaScript控制台(一般是F12),并修改app.message的值,如下图你将看到上例相应的更新:

除了文本插值,我们还可以像这样来绑定元素特性,并且看到的效果如图的右侧所示:

 

    这里我们遇到了一些新的东西。 v-bind 特性被称为指令。指令带有前缀 v- 以表示它们是 vue 提供的特殊特性。它们会在渲染的 DOM 上应用特殊的响应式行为。 在这里,该指令的意思是:“将这个元素节点的 tittle 特性和 Vue 实例的 message 属性保持一致。”

    这个时候如果再次打开浏览器的 JavaScript 控制台,输入 vm.message = '新消息', 就会看到这个绑定了 tittle 特性的 HTML 已经进行了更新,如图所示:

条件与循环

以下实例实现了,控制切换一个元素是否显示:

  这个例子演示了我们不仅可以把数据绑定到DOM文本或特性,还可以绑定到DOM结构。此外,Vue也提供了一个强大的过渡效果系统,可以在Vue插入/更新/移除元素时自动应用过渡效果。

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

在控制台,通过vm.todos.push({text:'新项目'}),发现在最后添加列表。

处理用户输入

为了让用户和你的应用进行交互,我们可以使用 v-on 指令添加一个事件监听器,通过它调用在vue实例中定义的方法:

注意在 reverseMessage 方法中,我们更新了应用的状态,但没有触碰 DOM--所有的DOM操作都由 Vue 来处理,编写的代码只需要关注逻辑层面即可。

Vue还提供了 v-model 指令,它能轻松实现表单输入和应用状态之间的双向绑定。

 

 

### Vue.js 基础知识总结与归纳 Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,其核心库专注于视图层,能够轻松集成到现有项目中[^3]。以下是关于 Vue.js 的基础知识总结和归纳: #### 1. 核心概念 - **MVVM 模式**:Vue 实现了 MVVM(Model-View-ViewModel)模式,开发者通过绑定数据模型(Model)和视图(View),使得数据变化时视图会自动更新。 - **模板语法**:Vue 使用双大括号 `{{ }}` 表达式将数据插入到 HTML 中[^2]。 - **指令**:Vue 提供了一些内置指令(如 `v-if`、`v-for`、`v-bind` 和 `v-on`),用于操作 DOM[^2]。 #### 2. 生命周期 Vue 实例从创建到销毁的过程称为生命周期。以下是关键的生命周期钩子: - `beforeCreate`:实例初始化完成,但尚未挂载数据或事件监听器。 - `created`:实例已完成数据观测,但尚未挂载到 DOM。 - `beforeMount`:模板已编译,但尚未渲染到页面上。 - `mounted`:实例已被挂载到 DOM 上,可以访问真实 DOM[^5]。 - `beforeUpdate`:当数据发生变化时触发,此时 DOM 尚未更新。 - `updated`:DOM 已经根据最新的数据完成更新[^5]。 - `beforeDestroy` 和 `destroyed`:实例即将销毁或已经销毁。 #### 3. 数据绑定 - **单向绑定**:通过 `v-bind` 指令实现父组件向子组件传递数据。 - **双向绑定**:通过 `v-model` 指令实现表单输入与数据之间的同步[^2]。 #### 4. 组件化开发 - **局部组件**:在 `components` 属性中定义组件,并在模板中使用。 - **全局组件**:通过 `Vue.component` 方法注册全局组件。 - **Props 和 Events**:`props` 用于父组件向子组件传递数据,`$emit` 用于子组件向父组件发送事件。 #### 5. 路由管理 Vue Router 是官方提供的路由管理器,用于构建单页面应用中的路由系统。通过配置路由规则,可以实现页面间的切换和参数传递。 #### 6. 状态管理 Vuex 是 Vue 官方的状态管理库,适用于管理复杂的应用状态。它提供了集中式的存储机制,使组件间共享状态变得更加高效。 #### 7. 过渡效果与动画 Vue 提供了丰富的过渡效果支持,包括 CSS 动画、JavaScript 钩子函数等,用于增强用户体验。 #### 8. 插件系统 Vue 具有强大的插件系统,可以通过安装插件扩展核心功能。例如,`vue-router` 和 `vuex` 都是以插件形式提供的。 #### 示例代码 以下是一个简单的 Vue 实例示例: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue Example</title> <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js"></script> </head> <body> <div id="app"> {{ message }} </div> <script> new Vue({ el: '#app', data: { message: 'Hello Vue!' } }); </script> </body> </html> ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值