「网页开发|前端开发|Vue」04 快速掌握开发网站需要的Vue基础知识
本文主要介绍使用Vue进行前端开发的一些必备知识,比如:Vue应用实例,Vue的组件概念,模板语言和模板语法,计算属性,路由配置等等。
文章目录
- 本系列前文传送门
- 前言
- 一、Vue实例:项目入口
- 二、模板语言:Vue如何编写页面
- 三、模板语法:类编程语言的设计
- 四、计算属性与监听属性
- **计算属性具体用法如下:**
- 监听属性具体用法如下:
- 五、生命周期与Hook函数
- 本系列下一篇文章传送门
本系列前文传送门
- 「网页开发|前端开发|Vue」01 快速入门:快速写一个Vue的HelloWorld项目
- 「网页开发|前端开发|Vue」02 从单页面到多页面网站:使用路由实现网站多个页面的展示和跳转
- 「网页开发|前端开发|页面布局」03 学会够用的CSS,实现任意你想要的页面布局
前言
在了解Vue项目的文件结构、如何通过路由拥有多页面网站以及如何去实现单个页面的元素布局之后,我们就需要去实现具体单个页面的内容了。
因此我们就需要在使用html编写页面的基础上,掌握一些vue的特性来帮助编写页面内容以及页面数据的处理和变化。
一、Vue实例:项目入口
我们要使用Vue来搭建网站,就需要实例化一个Vue对象来代表一个Vue应用,如下:
// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
new Vue({......
})
我们来看一个具体的网站Vue实例:
<div id="app"><p>{{message}}</p>
</div><script type="text/javascript">var vm = new Vue({el: '#app',data: {message: "Hello Vue World!"},methods: {printMessage: function() {console.log(this.message)}}})
</script>
这里Vue({})
中有三个参数:el
, data
, methods
:
el
代表要挂在的HTML元素的iddata
初始化了一些数据给页面,这里初始化了变量message
的值为Hello Vue World!
,而html代码中用{{ message }}
表示这里使用message
的值作为渲染内容method
则是用来定义供页面使用的方法,这里定义了printMessage()
方法,调用后会在控制台输出message
的值
一个Vue应用代表一个网站,一个网站一般会有多个页面,对应到Vue中成为多个组件。一般来说,每个页面都是应用的一个组件,页面中需要被重复用的的部分也会单独拆分成一个组件。
我们在「网页开发|前端开发|Vue」01 快速入门:快速写一个Vue的HelloWorld项目中已经探索了使用脚手架工具生成的标准化Vue项目文件的结构以及各个代码之间的流转,可以回看加深一下理解。
二、模板语言:Vue如何编写页面
我们一般会将 Vue 组件定义在一个单独的 .vue 文件中,叫做单文件组件。
Vue扩展了HTML,称之为模板。任何合乎规范的 HTML 都是合法的 Vue 模板,在一个XXXX.vue
文件中,会有<template></template>
标签,在其中是HTML
代码(这些HTML
将最终被渲染成浏览器页面),如下:
<template><div class="hello"><h1>Hello World</h1></div>
</template>
这使得如果熟悉html
语言,可以快速开发vue
网站应用的开发。
在同一个XXXX.vue
文件中,会有CSS
代码,默认这些样式代码只针对这个文件中的HTML
元素有效,如下:
<style scoped>
h1 {font-weight: normal;
}
</style>
这里的scoped
属性是一个可选属性,加上之后会自动添加一个唯一的 attribute (比如 data-v-21e5b78
) 为这个文件中内 CSS 指定作用域,编译的时候 .list-container:hover 会被编译成类似 h1[data-v-21e5b78]
。
同样的,XXXX.vue
文件中也会有javascript
代码,以<script></script>
包括起来,如下:
<script>
export default {name: 'HelloWorld',data() {return {msg: 'Hello Vue World!'}}
}
</script>
总而言之,我们只需要记住Vue
所谓的模板
就是将一个页面的HTML
, CSS
以及javascript
代码单独放到一起的XXXX.vue
文件。当我们要编写一个页面的时候,我们只需要在对应的.vue
文件中编写代码即可。
我们在「网页开发|前端开发|Vue」02 从单页面到多页面网站:使用路由实现网站多个页面的展示和跳转 中已经介绍了如何将展示一个页面的网站,通过路由设计拓展成展示多个页面的网站,可以回看加深理解。
三、模板语法:类编程语言的设计
因为Vue的模板可以理解是扩展了的HTML,Vue提供了一些类似编程语言语法关键字的模板语法来帮助开发,也叫做指令。
Vue官网介绍,一个指令的本质是模板中出现的特殊标记,让处理模板的库知道需要对这里的 DOM 元素进行一些对应的处理。
指令的前缀是默认的 v-,常见指令如下:
v-if
: 条件判断,当if条件为true时元素才会存在(注意,是直接在页面源代码中不存在这个元素的代码)。当有多个条件分支的时候会搭配v-else-if
,v-else
来使用。
<div id="app"><div v-if="type === 'A'">A</div><div v-else-if="type === 'B'">B</div><div v-else-if="type === 'C'">C</div><div v-else>type is not A or B or C</div>
</div>
v-show
: 与v-if
相似,用来控制是否展示某些元素。但v-if
结果为false
的时候页面源代码里不会有对应元素的代码,但是v-show
为false
的时候,页面源代码中也会有对应元素的代码,只是我们在浏览器渲染的页面中看不到而已。v-for
:- for循环,主要用来处理数组,通过遍历来展示多个元素
- 注意,比如希望得到一个
<ul>
中有多个<li>
的结果,v-for
应该写在<li>
中
v-bind
:- 当元素属性(比如
class
)的值需要用到data
里面定义的变量时,需要使用v-bind
来标记 - 比如
<div v-bind:class="{ isActive?'active':'default' }">
表示,如果当变量isActive
的值为true,则class='active'
,否则class='default'
v-bind:class="{ isActive?'active':'default' }"
也可以简写成:class="{ isActive?'active':'default' }"
- 当元素属性(比如
v-on
:- 与
v-bind
类似,v-bind
是在元素属性上绑定逻辑,v-on
则是在元素事件上绑定逻辑。 - 比如
<button v-on:click="counter += 1">增加 1</button>
是给button
的click
事件绑定了counter+=1
的逻辑,使得每次点击Button都会将counter
的值加一 v-on:click="counter += 1"
可以简写成@click="counter += 1"
- 与
v-model
: 用来在表单控件元素上(比如input
)绑定某个数据变量,然后就可以通过表单控件来修改变量的值。
<div id="app"><p>input 元素:</p><input v-model="message" placeholder="编辑我……"><p>消息是: {{ message }}</p>
</div><script>
new Vue({el: '#app',data: {message: 'input what you want',}
})
</script>
我们看到这里在通过new Vue({...})
创建了一个实例,然后实例化的同时初始化了变量message
的值为input what you want
,然后通过v-model
将变量message
绑定到<input>
上,这个时候如果我们修改输入框中的内容,这个新的内容就会成为变量message
新的值,相当于提供了通过用户输入修改变量值的途径,或者说提供了存储用户输入的途径。
四、计算属性与监听属性
直接在模板中的用变量的表达式虽然方便,但也只能用来做简单的操作。如果在模板中写太多逻辑,会让模板变得臃肿,难以维护,于是就有了计算属性和监听属性:
- 计算属性:我们可以指定通过一个变量A,去计算变量B,当A发生变化的时候,B会跟着重新计算。
- 监听属性:指定监听一个变量A,当变量A变化时,都会执行编写好的逻辑。这里的逻辑可以是计算也可以是其他的。
- 计算属性是为了及时更新值(计算逻辑只是得到值的手段),而监听属性是为了执行预定逻辑。
计算属性具体用法如下:
<template>
<div id="app"><button @click="count += 1">增加 1</button><p>Count: {{ count }}</p><p>Double Count: {{doubleCount}}</p>
</div>
</template>
<script>
export default {data() {return {count:1}},computed: {// 每当 count 改变时,这个函数就会执行doubleCount() {return this.count * 2}}
}
</script>
这里当我们点击button
按钮使得变量count
加一之后,doubleCount
会重新计算。
注意,这里在computed
的doubleCount
函数体中要访问data()
中定义的count
,需要使用this
来定位,不然会无法找到变量从而抛出如下的ReferenceError
错误:
vue.esm.js:3767 ReferenceError: count is not definedat VueComponent.doubleCount (HelloWorld.vue:19:1)at Watcher.get (vue.esm.js:4164:1)at Watcher.evaluate (vue.esm.js:4265:1)at VueComponent.computedGetter [as doubleCount] (vue.esm.js:4490:1)at Object.get (vue.esm.js:706:1)at Proxy.render (HelloWorld.vue:16:1)at Vue._render (vue.esm.js:2540:1)at VueComponent.updateComponent (vue.esm.js:2980:1)at Watcher.get (vue.esm.js:4164:1)at new Watcher (vue.esm.js:4154:1)
监听属性具体用法如下:
<template><div id="app"><button @click="count += 1">点击</button><p>Count: {{ count }}</p></div>
</template>
<script>
export default {data() {return {count: 1}},watch: {// 每当 count 改变时,这个函数就会执行count(newValue, oldValue) {alert(`count从 ${oldValue} 增加到了 ${newValue}`)}}
}
</script>
这里watch中定义的count
监听逻辑会有两个参数代表原值和新值,我们可以在逻辑中使用这两个值做一些判断或者计算。
五、生命周期与Hook函数
生命周期是一个类比人类生命的技术术语,用来表示元素或者说组件从被创建、初始化、渲染更新、再次渲染、卸载(移除)等一系列过程。
Vue 组件完整的生命周期包括,创建组件、初始化数据、编译模板、挂载 DOM、渲染、更新、再次渲染、卸载等一系列过程。
在这些过程的前后我们都要执行相应的方法,这些方法就叫做Hook(钩子)函数。而在Vue 组件的生命周期中有 8 个常用的钩子函数,我们可以在刚才的代码中加入各个生命周期Hook函数来测试效果,如下:
<template><div id="app"><button @click="count += 1">点击</button><p>Count: {{ count }}</p></div>
</template>
<script>
export default {data() {return {count: 1}},watch: {// 每当 count 改变时,这个函数就会执行count(newValue, oldValue) {alert(`count从 ${oldValue} 增加到了 ${newValue}`)}},beforeCreate() {console.log(`the vue is beforeCreate.`)},created() {console.log(`the vue is created.`)},beforeMount() {console.log(`the vue is beforeMount.`)},mounted() {console.log(`the vue is mounted.`)},beforeUpdate() {console.log(`the vue is beforeUpdate.`)},updated() {console.log(`the vue is updated.`)},beforeDestroy() {console.log(`the vue is beforeDestroy.`)},destroyed() {console.log(`the vue is destroyed.`)}
}
</script>
回到浏览器页面使用F12打开开发者工具,可以在console控制台中看到如下输出:
the vue is beforeCreate.
the vue is created.
the vue is beforeMount.
the vue is mounted.
点击按钮之后,可以看到console中额外有如下输出信息:
the vue is beforeUpdate.
the vue is updated.
所以我们可以看到,当浏览器执行代码进行页面渲染的时候,会依次执行创建组件的Hook函数(beforeCreate()
和created()
)和挂载的Hook函数(beforeMount()
和mounted()
)。
当我们进行点击或者其他交互行为时,页面元素或组件更新进行再次渲染,会触发更新的Hook函数(beforeUpdate()
和updated()
),而当卸载组件时才会触发卸载的Hook函数(beforeDestroy()
和destroyed()
)
以上就是在Vue开发过程中主要会使用到的内容,至于其他更加细致针对具体应用场景的用法,直接在遇到具体开发场景时,查阅Vue文档即可。
本系列下一篇文章传送门
- 「网页开发|前端开发|Vue」05 Vue实战:从零到一实现一个网站导航栏
写文不易,如果对你有帮助的话,来一波点赞、收藏、关注吧~👇
相关文章:
「网页开发|前端开发|Vue」04 快速掌握开发网站需要的Vue基础知识
本文主要介绍使用Vue进行前端开发的一些必备知识,比如:Vue应用实例,Vue的组件概念,模板语言和模板语法,计算属性,路由配置等等。 文章目录 本系列前文传送门前言一、Vue实例:项目入口二、模板语…...
解决Redis分布式锁主从架构锁失效问题的终极方案 含面试题
面试题分享 2023最新面试合集链接 2023大厂面试题PDF 面试题PDF版本 java、python面试题 项目实战:AI文本 OCR识别最佳实践 AI Gamma一键生成PPT工具直达链接 玩转cloud Studio 在线编码神器 玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间 史上最全文档AI绘画stab…...
建站系列(三)--- 网络协议
目录 相关系列文章前言一、定义二、术语简介三、协议的组成要素四、网络层次划分五、常见网络协议划分六、常用协议介绍(一)TCP/IP(二)HTTP协议(超文本传输协议)(三)SSH协议 相关系列…...
jetson orin nx无显示器启动
sudo apt-get install xserver-xorg-core-hwe-18.04 sudo apt-get install xserver-xorg-video-dummy在 /usr/share/X11/xorg.conf.d/ 中添加 xorg.conf 文件。 Section "Monitor"Identifier "Monitor0"HorizSync 28.0-80.0VertRefresh 48.0-75.0Modeline…...
【APUE】标准I/O库
目录 1、简介 2、FILE对象 3、打开和关闭文件 3.1 fopen 3.2 fclose 4、输入输出流 4.1 fgetc 4.2 fputc 4.3 fgets 4.4 fputs 4.5 fread 4.6 fwrite 4.7 printf 族函数 4.8 scanf 族函数 5、文件指针操作 5.1 fseek 5.2 ftell 5.3 rewind 6、缓冲相关 6.…...
es6---模块化
main.js import { bar } from "./module1"; import module2 from "./module2"; bar() module2()module1.js // 多变量导出,导入变量需要变量名一对一映射 export const module1module1 export function bar(params) {console.log(module1) }m…...
【项目 计网12】4.32UDP通信实现 4.33广播 4.34组播 4.35本地套接字通信
文章目录 4.32UDP通信实现udp_client.cudp_server.c 4.33广播bro_server.cbro_client.c 4.34组播multi_server.cmulti_client.c 4.35本地套接字通信ipc_server.cipc_client.c 4.32UDP通信实现 udp_client.c #include <stdio.h> #include <stdlib.h> #include <…...
创建简单的 Docker 数据科学映像
推荐:使用NSDT场景编辑器快速搭建3D应用场景 为什么选择 Docker for Data Science? 作为一名数据科学家,拥有一个标准化的便携式分析和建模环境至关重要。Docker 提供了一种创建可重用和可共享的数据科学环境的绝佳方法。在本文中ÿ…...
angualr:CSS一个div内两个子元素的高度自适应
问题: 如题 参考: CSS一个div内两个子元素的高度自适应-腾讯云开发者社区-腾讯云...
Java基础之static关键字
目录 静态的特点第一章、静态代码块第二章、静态属性第三章、静态方法调用静态方法时静态方法中调用非静态方法时 第四章、static关键字与其他关键字 友情提醒 先看文章目录,大致了解文章知识点结构,点击文章目录可直接跳转到文章指定位置。 静态的特点…...
iPhone 15 Pro有5项重大设计升级,让iPhone 15看起来很无聊
距离苹果9月份的发布会还有不到一周的时间,我们很快就会第一次看到iPhone 15系列。源源不断的传言表明,这一代人将对大多数机型进行另一次增量更新,这对那些想换iPhone 14或更旧手机的人来说是个坏消息。 但这一次的高端选择,iPh…...
xCode14.3.1运行MonkeyDev出现“Executable Not Found“的解决办法
安装MonkeyDev遇到的坑 环境:Xcode Version 14.3.1 (14E300c) 错误提示 is not a valid path to an executable file. 报错 /Users/xxxx//Library/Developer/Xcode/DerivedData/MonTest-ccparhdyzjuqhjdergwrngpfwwoh/Build/Products/Debug-iphoneos/MonTest.app…...
C# Emgu.CV+Tesseract实现识别图像验证码
效果图,简单的还行,复杂的。。。拉跨 懒得写讲解了,全部源码直接上吧 /// <summary>/// 验证码识别/// </summary>public partial class FrmCodeIdentify : FrmBase{private string _filePath;// 原图像Image<Bgr, byte> …...
ORACLE 11.2.0.4 RAC Cluster not starting cssd with Cannot get GPnP profile
最近,处理一次oracle 11.2.0.4 rac cluster由于cssd无法启动,导致集群一个节点的CRS集群无法正常启动的故障。原本,计划变更是从ASM剔除磁盘,解除存储到数据库服务器的映射;磁盘已经成功从ASM剔除,也已经成…...
Converting Phase Noise to Random Jitter(Cycle-to-Cycle)
借用Phase Noise to Random Jitter(Period)的转换过程推导了Cycle to Cycle random Jitter,一般展频时钟调制,用来评估相邻周期的随机抖动。...
HashMap知识总结
HashMap: 1. 扰动函数hash值右移16位与原hash值做异或运算得出的新hash值散列程度高. 2. 负载因子0.75,就是说一个数组初始化new HashMap(17)容量会比17最小2的n次方大,就是32,想要已空间换时间,就是负载因子小于0.75这样的话hash冲突更低,但是扩容频率更高.3 扩容,jdk…...
PLC编码器测速(限幅滤波+中心差分法求导SCL源代码)
M法测速的基本原理,大家可以查看专栏的系列文章,这里不再赘述常用链接如下: PLC通过编码器反馈值计算速度的推荐做法(算法解析+ST代码)_编码器脉冲怎么转换为速度_RXXW_Dor的博客-CSDN博客PLC如何测量采集编码器的位置数据,不清楚的可以参看我的另一篇博文:三菱FX3U PLC…...
SW的stp文件转成CAD格式文件学习笔记
SW的stp文件转成CAD格式文件 文章目录 SW的stp文件转成CAD格式文件另存为part文件(零件图)另存为CAD文件 另存为part文件(零件图) 如图一个STP文件,右上角标注是什么文件呢 另存为零件图,即另存为part …...
【数据结构】栈---C语言版(详解!!!)
文章目录 🐸一、栈的概念及结构🍄1、栈的概念定义🍄2、动图演示🌲入栈🌲出栈🌲整体过程 🐸二、栈的实现🐸三、数组结构栈详解🍎创建栈的结构⭕接口1:定义结构…...
sqlserver 联表查询、子查询、窗口函数、聚合函数等概念与例子
with cte as的用法 查询的一个有用工具,允许创建临时命名结果集,可在查询中多次引用相同的子查询结果,可以提高查询的可读性和维护性 WITH cte_name (column1, column2, ...) AS (-- 这里是子查询SELECT column1, column2, ...FROM your_ta…...
GO学习之 消息队列(Kafka)
GO系列 1、GO学习之Hello World 2、GO学习之入门语法 3、GO学习之切片操作 4、GO学习之 Map 操作 5、GO学习之 结构体 操作 6、GO学习之 通道(Channel) 7、GO学习之 多线程(goroutine) 8、GO学习之 函数(Function) 9、GO学习之 接口(Interface) 10、GO学习之 网络通信(Net/Htt…...
搭建自己的OCR服务,第三步:PPOCRLabel标注工具安装
一、安装说明 安装好了PaddleOCR后,还需要安装PPOCRLabel这个标注工具,想要自己训练模型的话,有个标注工具会起很大作用。 尤其是PPOCRLabel就是跟PaddleOCR配套的标注工具,同样是开源的。 在下载 PaddleOCR 整个源码中&#x…...
Java学习笔记37——网络编程01
网络编程入门 网络编程入门网络编程概述网路编程的三要素ip地址InetAddress类的使用端口 网络编程入门 网络编程概述 计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理…...
powershell 搜索文本并返回行号
目录 powershell 搜索文本并返回行号 python调用powershell搜索文本并返回行号; powershell 搜索文本并返回行号 $keyword PS dir "d:\" -Filter "*.txt" -Recurse | foreach {$line 0 $fileName $_.FullNameGet-Content $fileName | f…...
网络原理
网络原理 传输层 UDP 特点 特点:无连接,不可靠,面向数据报,全双工 格式 怎么进行校验呢? 把UDP数据报中的源端口,目的端口,UDP报文长度的每个字节,都依次进行累加 把累加结果&a…...
力扣(LeetCode)算法_C++——同构字符串
给定两个字符串 s 和 t ,判断它们是否是同构的。 如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。 每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一个字符上,相…...
网管实战⑼:配置华为S5720交换机
配置好汇聚交换机后,需要根据单位情况配置具体的接入交换机。 自从2019年12月底配置好交换机后,基本上都没有怎么操作交换机了。那时候使用的是H3C交换机,主要是H3C S7706、H3C S5120、H3C S5130、H3C S5500、H3C S3600等型号的交换机&#x…...
文件上传漏洞第十六关十七关
第十六关 第十七关 第十六关 直接上传php文件判断限制方式: 同第十五关白名单限制 第十六关源码: 代码逻辑判断了后缀名、content-type,以及利用imagecreatefromgif判断是否为gif图片,最后再做了一次二次渲染 二次渲染图片马&…...
Try llama2 in NUC (by quqi99)
作者:张华 发表于:2023-09-06 版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明 ( http://blog.csdn.net/quqi99 ) 据说现在在PC机上可以运行llama2大模型了, Way 1 于是照…...
强大易用的开源 建站工具Halo
特点 可插拔架构 Halo 采用可插拔架构,功能模块之间耦合度低、灵活性提高。支持用户按需安装、卸载插件,操作便捷。同时提供插件开发接口以确保较高扩展性和可维护性。 ☑ 支持在运行时安装和卸载插件 ☑ 更加方便地集成三方平台 ☑ 统一的可配置设置表…...
网站服务器做下载链接/纯手工seo公司
//jQuery event封装支持判断元素上是否绑定了事件,此方法只适用于jQuery绑定的事件 var $events $("#testdiv").data("events"); if( $events && $events["click"] ){// 绑定 }else{ // 未绑定 } 转载于:https://www.cnblog…...
大连做网站的/百度广告关键词价格表
计算机基础导论葛卫民 王保旗 主编赵国瑞 主审出版社内容提要本书从应用计算机的角度出发,全面、系统地介绍了计算机系统软件和硬件的基本知识,对计算机在办公自动化、多媒体、数据库、网络和陨灶贼藻则灶藻贼等应用领域的概念和术语作了概要介绍&#x…...
网站备案幕布拍照是什么/seo服务价格表
文章引用至: https://www.cnblogs.com/panchunting/p/entity-framework-code-first-migrations.html 随着业务的增加, 之前code first创建的表可能已经不能满足需求, 比如增加一个字段, 这样就出来了‘Migrations’ 第一步&#x…...
网站代理工具/搜索引擎营销方法
关注云报洞察深一度好消息!工业和信息化部刚刚印发了《中小企业数字化转型指南》(以下简称“《指南》”),旨在从增强企业转型能力、提升转型供给水平等多个维度,助力中小企业科学高效推进数字化转型,提升为…...
学网站建设多久能学会/东莞市民最新疫情
1.冒泡排序 function bubbleSort($arr) { //计算数组长度 $length count($arr); //循环次数为数组长度 for ($m1; $m < $length; $m) { //循环与该位置之后的数字比较 for ($n0; $n < $length-$m; $n) { //如果当前数字比后一个数字大(从小到大)ÿ…...
政府门户网站建设方案下载/怎么给自己的公司做网站
MySQL 的 binlog 日志记录了数据库服务器上所有的数据更改操作,可以用来进行数据库备份、恢复、错误排查、数据同步等操作。 要手动解析 MySQL 的 binlog 日志,需要使用 MySQL 命令行客户端或者其他第三方工具。这里介绍使用 MySQL 命令行客户端的方法。…...