当前位置: 首页 > news >正文

day1 Vue学习

1.vue是什么?

一套用于构建用户界面的渐进式javaScript框架。

2.谁开发的?

3.vue特点

1。组件化

2.声明式。

4.学习vue之前基础

初识vue

<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>初识Vue</title> <!-- 引入Vue --> <script type="text/javascript" src="../js/vue.js"></script> </head> <body> <!-- 初识Vue: 1.想让Vue工作,就必须创建一个Vue实例,且要传入一个配置对象; 2.root容器里的代码依然符合html规范,只不过混入了一些特殊的Vue语法; 3.root容器里的代码被称为【Vue模板】; 4.Vue实例和容器是一一对应的; 5.真实开发中只有一个Vue实例,并且会配合着组件一起使用; 6.{{xxx}}中的xxx要写js表达式,且xxx可以自动读取到data中的所有属性; 7.一旦data中的数据发生改变,那么页面中用到该数据的地方也会自动更新; 注意区分:js表达式 和 js代码(语句) 1.表达式:一个表达式会产生一个值,可以放在任何一个需要值的地方: (1). a (2). a+b (3). demo(1) (4). x === y ? 'a' : 'b' 2.js代码(语句) (1). if(){} (2). for(){} --> <!-- 准备好一个容器 --> <div id="demo"> <h1>Hello,{{name.toUpperCase()}},{{address}}</h1> </div> <script type="text/javascript" > Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 //创建Vue实例 new Vue({ el:'#demo', //el用于指定当前Vue实例为哪个容器服务,值通常为css选择器字符串。 data:{ //data中用于存储数据,数据供el所指定的容器去使用,值我们暂时先写成一个对象。 name:'atguigu', address:'北京' } }) </script> </body> </html>

模板语法

<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>模板语法</title> <!-- 引入Vue --> <script type="text/javascript" src="../js/vue.js"></script> </head> <body> <!-- Vue模板语法有2大类: 1.插值语法: 功能:用于解析标签体内容。 写法:{{xxx}},xxx是js表达式,且可以直接读取到data中的所有属性。 2.指令语法: 功能:用于解析标签(包括:标签属性、标签体内容、绑定事件.....)。 举例:v-bind:href="xxx" 或 简写为 :href="xxx",xxx同样要写js表达式, 且可以直接读取到data中的所有属性。 备注:Vue中有很多的指令,且形式都是:v-????,此处我们只是拿v-bind举个例子。 --> <!-- 准备好一个容器--> <div id="root"> <h1>插值语法</h1> <h3>你好,{{name}}</h3> <hr/> <h1>指令语法</h1> <a v-bind:href="school.url.toUpperCase()" x="hello">点我去{{school.name}}学习1</a> <a :href="school.url" x="hello">点我去{{school.name}}学习2</a> </div> </body> <script type="text/javascript"> Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 new Vue({ el:'#root', data:{ name:'jack', school:{ name:'尚硅谷', url:'http://www.atguigu.com', } } }) </script> </html>

数据绑定

<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>数据绑定</title> <!-- 引入Vue --> <script type="text/javascript" src="../js/vue.js"></script> </head> <body> <!-- Vue中有2种数据绑定的方式: 1.单向绑定(v-bind):数据只能从data流向页面。 2.双向绑定(v-model):数据不仅能从data流向页面,还可以从页面流向data。 备注: 1.双向绑定一般都应用在表单类元素上(如:input、select等) 2.v-model:value 可以简写为 v-model,因为v-model默认收集的就是value值。 --> <!-- 准备好一个容器--> <div id="root"> <!-- 普通写法 --> <!-- 单向数据绑定:<input type="text" v-bind:value="name"><br/> 双向数据绑定:<input type="text" v-model:value="name"><br/> --> <!-- 简写 --> 单向数据绑定:<input type="text" :value="name"><br/> 双向数据绑定:<input type="text" v-model="name"><br/> <!-- 如下代码是错误的,因为v-model只能应用在表单类元素(输入类元素)上 --> <!-- <h2 v-model:x="name">你好啊</h2> --> </div> </body> <script type="text/javascript"> Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 new Vue({ el:'#root', data:{ name:'尚硅谷' } }) </script> </html>

el和data的二种写法

<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>el与data的两种写法</title> <!-- 引入Vue --> <script type="text/javascript" src="../js/vue.js"></script> </head> <body> <!-- data与el的2种写法 1.el有2种写法 (1).new Vue时候配置el属性。 (2).先创建Vue实例,随后再通过vm.$mount('#root')指定el的值。 2.data有2种写法 (1).对象式 (2).函数式 如何选择:目前哪种写法都可以,以后学习到组件时,data必须使用函数式,否则会报错。 3.一个重要的原则: 由Vue管理的函数,一定不要写箭头函数,一旦写了箭头函数,this就不再是Vue实例了。 --> <!-- 准备好一个容器--> <div id="root"> <h1>你好,{{name}}</h1> </div> </body> <script type="text/javascript"> Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。 //el的两种写法 /* const v = new Vue({ //el:'#root', //第一种写法 data:{ name:'尚硅谷' } }) console.log(v) v.$mount('#root') //第二种写法 */ //data的两种写法 new Vue({ el:'#root', //data的第一种写法:对象式 /* data:{ name:'尚硅谷' } */ //data的第二种写法:函数式 data(){ console.log('@@@',this) //此处的this是Vue实例对象 return{ name:'尚硅谷' } } }) </script> </html>
http://www.jsqmd.com/news/641281/

相关文章:

  • 实战指南:Intel I350系列网卡PXE功能精准配置与状态诊断
  • Windows热键冲突终极解决方案:3分钟快速定位占用程序的完整指南
  • Hermes-Agent 新手安装指南(言简意赅版)
  • MacPort vs Homebrew:实测PHP安装速度对比及多版本管理技巧(附避坑指南)
  • 保姆级教程:手把手教你用CANoe/LINalyzer分析LIN诊断报文(附PDU结构拆解)
  • posting替换postman(好像还是不太好用)
  • 艾尔登法环存档迁移终极指南:如何用 EldenRingSaveCopier 安全备份和转移你的角色
  • 从零上手MCP:手把手教你搭建第一个AI工具箱
  • 腾讯云轻量服务器新用户避坑指南:从宝塔面板到Docker环境,我的30天免费体验全记录
  • 多模态情感分析不再“黑盒”:SITS2026开源可解释性工具包(含Grad-CAMv3+Attention Gate可视化模块)
  • Netrunner 23评测:日常办公、娱乐、游戏一把抓,这款Linux发行版表现如何?
  • Python+SymPy实战:5分钟搞定不定积分与定积分计算(附常见错误排查)
  • AI编程实战:用Cursor从零构建带任务看板的项目管理系统
  • ERPC 法兰克福专有裸金属服务器技术架构解析——面向 Solana 高频交易的极致性能优化
  • 蚁群算法与动态窗口法融合的机器人路径规划系统解析
  • 成都地区晋南产热轧H型钢(1998-Q235B;100-1000mm)现货厂家 - 四川盛世钢联营销中心
  • Mermaid在线编辑器:免费实时图表创作工具的终极解决方案
  • 从航空到工业:Amphenol PCD互连方案应用与国产替代策略解析
  • 从零构建基于FreeRTOS的智能家居环境监控系统(含完整源码)
  • 小白程序员必看:轻松掌握大模型工具调用,让AI真正“动起来”并加入收藏!
  • easypostman替代postman
  • 银河麒麟V4.0.2-sp4服务器网络配置保姆级教程:从静态IP到DNS解析,一次搞定
  • 心得
  • 仅限首批200家律所获取的技术简报:SITS2026法律助手核心模块已封装为ISO/IEC 23894-compliant SDK(含GDPR+《人工智能法》双合规接口)
  • 极域电子教室破解终极指南:3分钟解锁学生端控制限制
  • 【小呆的热力学笔记】熵增原理与四大热力过程解析
  • 如何避免职业停滞?测试工程师的5年跃迁计划
  • 缓存架构设计实践
  • TI FMCW毫米波雷达进阶(2)——多目标测速与分辨率解析
  • 【人工智能训练师3级】考试准备(2026)六、实操题-简答部分2.2.1-2.2.5模型训练分析