【Web开发手礼】探索Web开发的秘密(十四)-Vue2(1)Node.js的安装、Vue入门

devtools/2024/10/19 7:29:30/

主要介绍了Node.js的安装教程、Vue2常用的一些指令、声明周期!!!

文章目录

前言

Node.js安装

选择安装目录

验证NodeJS环境变量 

配置npm的全局安装路径

切换npm的淘宝镜像

 安装Vue-cli

​编辑 Vue2入门

vue.js%E6%96%87%E4%BB%B6-toc" style="margin-left:40px;">引入vue.js文件

 入门代码

常用指令

 生命周期

总结


前言

主要介绍了Node.js的安装教程、Vue2常用的一些指令、声明周期!!!


Node.js安装

安装地址

 

选择安装目录

选择安装到一个,没有中文,没有空格的目录下(新建一个文件夹NodeJS)

 

验证NodeJS环境变量 

NodeJS 安装完毕后,会自动配置好环境变量,我们验证一下是否安装成功,通过:

 node -v

配置npm的全局安装路径

 

使用管理员身份运行命令行,在命令行中,执行如下指令:

npm config set prefix "安装路径"

切换npm的淘宝镜像

 使用管理员身份运行命令行,在命令行中,执行如下指令:

npm config set registry https://registry.npm.taobao.org

 安装Vue-cli

npm install -g @vue/cli

这个过程中,会联网下载,可能会耗时几分钟,耐心等待。

 Vue2入门

vue.js%E6%96%87%E4%BB%B6">引入vue.js文件

我们可以通过下载路径直接下载vue.js文件,然后放到script文件夹下面,通过script标签引入。

<script src="./js/vue.js"></script>

也可以引入在线路径vue.js文件

<script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script>

 入门代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="./js/vue.js"></script>
</head>
<body><div id="app"><input type="text" v-model="message">{{message}}</div>
</body>
<script>new Vue({el: '#app',data: {message: 'hello Vue'}})
</script>
</html>

常用指令

指令:HTML 标签上带有 v- 前缀 的特殊属性,不同指令具有不同含义。例如:v-if,v-for… 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="./js/vue.js"></script>
</head>
<body><div id="app"><a v-bind:href="url">百度</a><br><a :href="url">百度</a></div>
</body>
<script>new Vue({el: '#app',data: {url: 'https://www.baidu.com'}})
</script>
</html>
<input type="text" v-model="url">

 

 通过v-bind或者v-model绑定的变量,必须在数据模型中声明。

<input type="button" value="按钮" v-on:click="handle()"><input type="button" value="按钮" @click="handle()">
<script>new Vue({el: "#app",data: {//...},methods: {handle:function(){alert('我被点击了');}},})
</script>

 

  • v-if 
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="./js/vue.js"></script>
</head>
<body><div id="app"><input type="text" v-model:age = "age">经判定为:<span v-if="age <= 35">年轻人</span><span v-else-if="age > 35 && age < 60">中年人</span><span v-else>老年人</span></div>
</body>
<script>new Vue({el: '#app',data: {age: 60,},methods: {handle:function(){alert("被点击")}},})
</script>
</html>

  • v-show 
年龄{{age}},经判定为:
<span v-show="age <= 35">年轻人</span>

 

<div v-for="addr in addrs">{{addr}}</div>
<div v-for="(addr,index) in addrs">{{index + 1}} : {{addr}}</div>
data: {. . .addrs: ['北京','上海','广州','深圳','成都','杭州']
},

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="./js/vue.js"></script>
</head><body><div id="app"><table border="1" cellspacing="0" width="60%"><tr><th>编号</th><th>姓名</th><th>年龄</th><th>性别</th><th>成绩</th><th>等级</th></tr><tr align="center" v-for="(user,index) in users"><td>{{index+1}}</td><td>{{user.name}}</td><td>{{user.age}}</td><td><span v-if="user.gender === 1 ">男</span><span v-else-if="user.gender === 2 ">女</span></td><td >{{user.score}}</td><td><span v-if="user.score >= 85">优秀</span><span v-else-if="user.score >= 60">及格</span><span v-else style="color: red;">不及格</span></td></table></div>
</body>
<script>new Vue({el: "#app",data: {users: [{name: "Tom",age: 20,gender: 1,score: 78},{name: "Rose",age: 18,gender: 2,score: 86},{name: "Jerry",age: 26,gender: 1,score: 90},{name: "Tony",age: 30,gender: 1,score: 52}]},methods: {}})
</script></html>

Body 内容

  • <body>: HTML 主体部分,包含页面的可见内容。
    • <div id="app">: Vue.js 应用的根元素,用来绑定 Vue 实例。
      • <table>: 表格元素,用于显示用户数据。
        • <tr>: 表格行,包含表头和用户数据。
          • <th>: 表头单元格,显示表格列的标题。
            • 列标题: 编号、姓名、年龄、性别、成绩、等级。
          • <td>: 表格数据单元格,显示具体的用户信息和计算出的等级。
            • {{ expression }}: Vue.js 插值表达式,用于在表格中动态显示 Vue 实例中的数据。
              • {{ index + 1 }}: 显示用户的编号。
              • {{ user.name }}{{ user.age }}{{ user.score }}: 显示用户的姓名、年龄和成绩。
              • 条件渲染 (v-ifv-else-ifv-else): 根据用户的性别和成绩显示不同的内容,如性别(男或女)和成绩等级(优秀、及格、不及格)。

Vue.js 部分

  • <script>: 包含 Vue.js 实例的配置和逻辑。
    • new Vue({}): 创建一个新的 Vue 实例。
      • el: "#app": 将 Vue 实例挂载到 id 为 "app" 的 DOM 元素上。
      • data: {}: Vue 实例的数据对象,包含一个名为 users 的数组,每个元素代表一个用户的信息。
      • methods: {}: 可以定义 Vue 实例的方法,目前示例中未定义具体方法。

 生命周期

  • 生命周期:指一个对象从创建到销毁的整个过程。 
  • 生命周期的八个阶段:每触发一个生命周期事件,会自动执行一个生命周期方法(钩子)

<script>new Vue({el: "#app",data: {},mounted() {console.log("Vue挂载完毕,发送请求获取数据");},methods: {},})
</script>

 mounted:挂载完成,Vue初始化成功,HTML页面渲染成功。(发送请求到服务端,加载数据)


总结

主要介绍了Node.js的安装教程、Vue2常用的一些指令、声明周期!!!


http://www.ppmy.cn/devtools/91200.html

相关文章

Bash Shell 脚本中的循环语句

文章目录 Bash Shell 脚本中的循环语句一、for 循环1.1 列表循环1.2 不带列表循环&#xff08;C 风格的 for 循环&#xff09; 二、案例示例2.1 打印 1-5 的数字2.2 打印 5 次 "hello world"2.3 打印 abcde2.4 输出 0-50 之间的偶数 三、应用技巧3.1 使用花括号和 se…

5G 网络切片

5G 业务分类 增强型移动宽带(eMBB) 传统数据业务&#xff0c;特点是高带宽超高可靠性低时延业务&#xff08;URLLC&#xff09;无人驾驶、工业自动化等业务, 特点是高可靠、低时延海量机器类通信(mMTC) 物联网&#xff0c;特点是大量连接&#xff0c;时延不敏感&#xff0c;数…

java计算机毕设课设—基于网络爬虫技术的网络新闻分析系统(附源码、文章、相关截图、部署视频)

这是什么系统&#xff1f; java计算机毕设课设—基于网络爬虫技术的网络新闻分析系统 基于网络爬虫技术的新闻分析系统&#xff0c;它能够实时抓取凤凰网、网易、新浪、搜狐等网站的新闻数据&#xff0c;提取正文和点击量&#xff0c;每日定时抓取。系统还能对抓取的新闻进行…

贝叶斯学习方法:几种方法介绍

目录 1 拉普拉斯还原-轻松贝叶斯深度学习2 具有归一化流的变分推理3 基于条件归一化流的多元概率时间序列预测 1 拉普拉斯还原-轻松贝叶斯深度学习 深度学习的贝叶斯公式已被证明具有令人信服的理论性质&#xff0c;并提供实用的功能优势&#xff0c;例如改进预测不确定性量化…

[最新2025]CentOS7安装Python3设置环境变量(软链接)

一、安装python3 【注意】全程在 root 权限下执行 1、先安装openssl&#xff0c;不然以后python会遇到出错&#xff1a;ModuleNotFoundError: No module named _ssl curl http://www.openssl.org/source/openssl-1.1.1.tar.gz -o openssl-1.1.1.tar.gz tar -zxvf openssl-1.1.1…

EMF矢量图工具Graphpad Prism(棱镜科研绘图工具)

Graphpad Prism 是一款功能强大、专业实用的棱镜科研绘图软件&#xff0c;专为科研工作者而设计研发&#xff0c;可帮助用户进行专业便捷的科研图像绘制&#xff0c;通过该款软件用户可以进行新型子列图进行创建&#xff0c;可以进行平滑的线性图进行绘制&#xff0c;可以说是一…

树莓派4/5:在无显示器(无屏幕)下的系统安装与远程控制

一、场景说明 树莓派4/5的价格不高&#xff0c;用户可以通过显示器、鼠标、键盘&#xff0c;像使用计算机一样使用树莓派。 然而&#xff0c;如果用户购买的是低运存版本&#xff0c;或者希望降低硬件成本&#xff0c;则可以选择安装无桌面版本的Lite系统&#xff0c;在不接入…

AI表情神同步!LivePortrait安装配置,一键包,使用教程

快手在AI视频这领域还真有点东西&#xff0c;视频生成工具“可灵”让大家玩得不亦乐乎。 现在又开源了一款超好玩的表情同步&#xff08;表情控制&#xff09;项目。 一看这图片&#xff0c;就知道是小视频平台出的&#xff0c;充满了娱乐性。发布没几天就已经有8000Star。 项…