Vue —— 基础(零)(模板语法、数据绑定、el/data写法、MVVM模型)

简介: Vue —— 基础(零)(模板语法、数据绑定、el/data写法、MVVM模型)

一、初识 Vue

1. 在页面输出 HELLO VUE!
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>初识Vue</title>
    <!-- 引入Vue -->
    <script src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备好一个容器 -->
    <div id="root">
        <h1>HELLO,{{message.toUpperCase()}}</h1>
    </div>
    <script>
        Vue.config.productionTip = false;   //阻止 vue 在启动时生成生产提示
        // 创建Vue实例 ({})只传一个参数,类型为对象(配置对象)
        new Vue({
            el: '#root',  //el用于指定当前Vue实例为哪个容器服务
            data: {     //data中用于存储数据,数据供el所指定的容器去使用,值暂时先写成一个对象
                message: 'Vue!',
            }
        })
    </script>
</body>
</html>

二、模板语法

Vue模板语法有 2 大类:

1. 插值语法

功能:用于解析标签体内容。

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

2. 指令语法

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

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

3. 简写方式

v-bind 简写为 :

v-on 简写为 @

4. 实例(插值语法和指令语法)

使用插值语法 {{xxx}} 和 v-bind 指令呈现内容

    <div id="root">
        <h1>插值语法</h1>
        <h3>你好,{{name}}</h3>
        <hr/>
        <h1>指令语法</h1>
        <a v-bind:href="school.url">{{school.name}}</a>
    </div>
    <script>
        new Vue({
            el:'#root',
            data:{
                name:'八岁',
                school:{
                    name:'哔哩哔哩',
                    url:'https://www.bilibili.com/'
                }
            }
        })
    </script>

ab059810da75431db22e6ed824533bc5.png

三、数据绑定

Vue中有两种数据绑定的方式:

1. 单向数据绑定(v-bind)

数据只能从 data 流向页面。

2. 双向数据绑定(v-model)

数据不仅能从 data 流向页面,还可以从页面流向 data。

3. 注意点
  1. 双向绑定一般都应用在表单类元素上 (如:input、select等)
  2. v-model:value 可以简写为 v-model,因为 v-model 默认就是 value 值。
4. 实例(完整写法)
  <div id="root">
        单向数据绑定: <input type="text" v-bind:value="name1">{{name1}}<br/>
        双向数据绑定: <input type="text" v-model:value="name2">{{name2}}<br/>
    </div>
    <script>
        new Vue({
            el:'#root',
            data:{
                name1:'单向数据绑定',
                name2:'双向数据绑定'
            }
        })
    </script>
5. 实例(简写方式)
  <div id="root">
        单向数据绑定: <input type="text" :value="name1">{{name1}}<br/>
        双向数据绑定: <input type="text" v-model="name2">{{name2}}<br/>
    </div>
    <script>
        new Vue({
            el:'#root',
            data:{
                name1:'单向数据绑定',
                name2:'双向数据绑定'
            }
        })
    </script>

2fae46ce16b4456da2ff81ca39ab6e7c.png

四、el 和 data 的两种写法

1. el 有2种写法
  1. new Vue 时配置 el 属性。
  2. 先创建 Vue 实例,随后再通过 vm.$mount('#root') 指定el的值。
2. data有2种写法
  1. 对象式
  2. 函数式
  3. 如何选择:目前哪种方法都可以,以后学习到 组件 时,data必须使用函数式,否则会报错。
  //对象式
  data: {
  }


  //函数式
  data() {
    return {
    }
  }
3. 一个重要的原则

由 Vue 管理的函数,一定不要写箭头函数,一旦写了箭头函数,this 就不再是 Vue 实例了。

4. el 的第一种写法
  <div id="root">
        <h1>你好,{{name}}</h1>
    </div>
    <script>
        new Vue({
            el:'#root',
            data:{
                name:'vue'
            }
        })
    </script>
5. el 的第二种写法
  <div id="root">
        <h1>你好,{{name}}</h1>
    </div>
    <script>
        var v = new Vue({
            data:{
                name:'vue'
            }
        })
        v.$mount("#root") 
    </script>
6. data 的第一种写法(对象式)
  <div id="root">
        <h1>你好,{{name}}</h1>
    </div>
    <script>
        new Vue({
            el:'#root',
            data:{
                name:'vue'
            }
        })
    </script>
7. data 的第二种写法 (函数式)
  <div id="root">
        <h1>你好,{{name}}</h1>
    </div>
    <script>
        new Vue({
            el:'#root',
            data:function(){
                return{
                    name:'vue'
                }
            }
        })
    </script>

五、MVVM 模型

1. M:模型(Model)

data 中的数据

2. V:视图(View)

模板代码

3. VM:视图模型(ViewModel)

Vue 实例

4. 注意点
  1. data 中所有的属性,最后都出现在了 vm 身上。
  2. vm 身上所有的属性 及 Vue 原型上所有属性,在 Vue 模板中都可以直接使用。
  <!-- div 里面是 View -->
    <div id="root">
        <h1>学校名称:{{name}}</h1>
        <h1>学校地址:{{address}}</h1>
    </div>
    <script>
        new Vue({  // new Vue({})是 ViewModel
            el: '#root',  
            data: {     
                name: '青岛',
                address: '山东'
                // data 里面的内容是 Model
            }
        })
    </script>

不积跬步无以至千里 不积小流无以成江海

相关文章
|
10天前
|
数据采集 监控 JavaScript
在 Vue 项目中使用预渲染技术
【10月更文挑战第23天】在 Vue 项目中使用预渲染技术是提升 SEO 效果的有效途径之一。通过选择合适的预渲染工具,正确配置和运行预渲染操作,结合其他 SEO 策略,可以实现更好的搜索引擎优化效果。同时,需要不断地监控和优化预渲染效果,以适应不断变化的搜索引擎环境和用户需求。
|
3天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
13天前
|
JavaScript
Vue 指令速查表
【10月更文挑战第12天】Vue 指令速查表
|
3天前
|
存储 JavaScript
Vue 状态管理工具vuex
Vue 状态管理工具vuex
|
10天前
|
缓存 JavaScript 搜索推荐
Vue SSR(服务端渲染)预渲染的工作原理
【10月更文挑战第23天】Vue SSR 预渲染通过一系列复杂的步骤和机制,实现了在服务器端生成静态 HTML 页面的目标。它为提升 Vue 应用的性能、SEO 效果以及用户体验提供了有力的支持。随着技术的不断发展,Vue SSR 预渲染技术也将不断完善和创新,以适应不断变化的互联网环境和用户需求。
29 9
|
9天前
|
缓存 JavaScript UED
Vue 中实现组件的懒加载
【10月更文挑战第23天】组件的懒加载是 Vue 应用中提高性能的重要手段之一。通过合理运用动态导入、路由配置等方式,可以实现组件的按需加载,减少资源浪费,提高应用的响应速度和用户体验。在实际应用中,需要根据具体情况选择合适的懒加载方式,并结合性能优化的其他措施,以打造更高效、更优质的 Vue 应用。
|
8天前
|
JavaScript
如何在 Vue 中使用具名插槽
【10月更文挑战第25天】通过使用具名插槽,你可以更好地组织和定制组件的模板结构,使组件更具灵活性和可复用性。同时,具名插槽也有助于提高代码的可读性和可维护性。
13 2
|
8天前
|
JavaScript
Vue 中的插槽
【10月更文挑战第25天】插槽的使用可以大大提高组件的复用性和灵活性,使你能够根据具体需求在组件中插入不同的内容,同时保持组件的结构和样式的一致性。
12 2
|
8天前
|
前端开发 JavaScript 容器
在 vite+vue 中使用@originjs/vite-plugin-federation 模块联邦
【10月更文挑战第25天】模块联邦是一种强大的技术,它允许将不同的微前端模块组合在一起,形成一个统一的应用。在 vite+vue 项目中,使用@originjs/vite-plugin-federation 模块联邦可以实现高效的模块共享和组合。通过本文的介绍,相信你已经了解了如何在 vite+vue 项目中使用@originjs/vite-plugin-federation 模块联邦,包括安装、配置和使用等方面。在实际开发中,你可以根据自己的需求和项目的特点,灵活地使用模块联邦,提高项目的可维护性和扩展性。
|
9天前
|
JavaScript 前端开发 UED
vue 提高 tree shaking 的效果
【10月更文挑战第23天】提高 Vue 中 Tree shaking 的效果需要综合考虑多个因素,包括模块的导出和引用方式、打包工具配置、代码结构等。通过不断地优化和调整,可以最大限度地发挥 Tree shaking 的优势,为 Vue 项目带来更好的性能和用户体验。