Vue框架;Vue中的选择和循环结构;Vue数据类型;Vue中的事件和动态属性;Vue子组件通过导入在主组件显示在网页;Vue中主组件向子组件传递数据
一,Vue简介
前端现在比较火的三大框架就是:vue ,React,Angular。在国内使用最多的还是:
vue >React >Angular
Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的 JavaScript 框架。它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,帮助你高效地开发用户界面。无论是简单还是复杂的界面,Vue 都可以胜任。
Vue代码分割为三类, HTML、CSS 和 JavaScript,三部分的代码在各自带区域写;
且:Vue是渐进式的JavaScript框架。意味着它可以在你现有的应用程序当中去插入,也可以单独的完整的去创建一个拥有vue环境的项目。
1.0项目src下的结构
registerServiceWorker.js 是一个测试文件。(可以删除,在把对应的引用关系删除掉 import ‘./registerServiceWorker’ 在main.js文件里。)
Main.js 主入口文件 基本上不用动,大部分用来导入文件。
组件化开发:
组件:由三种语法组成,html,css ,js
html部分:
<template><div></div></template>
js部分:
<script>export default {}</script>
css部分:
<style type="text/css"></style>
2.0Vue中的选择和循环结构
书写形式和java有差别,但是含义相同
选择结构:
v-if=“条件”
v-else if
v-else
<ol><li v-if="boo">起床吃早餐</li><li v-else>出发来上课</li><li>下课来吃饭</li><li>下课吃晚饭</li><li v-show="boo">下课吃夜宵</li></ol>
<!-- 如果boo为真,则“出发来上课” 不显示,反之只显示“出发来上课” -->
循环结构
<select >该部门下的所有员工<option v-for="(e,i) in names " :key="i">{{ e }}</option><!-- 循环 for v-for="(e,i) e是循环值 i是下标 --></select>
<!-- names是含有多个名称的数组 -->
3.0Vue数据类型
Vue的数据要声明和初始化在Js块中:
<script>
/* 属性加前加: 表示动态属性:属性值为变量*/
export default {name: 'App', /**1.当前页面名字:App 逗号隔开第二个属性 */data(){/** 2.设置当前页面的显示变量*/
/*想将变量反到前端页面,相当于成员变量,变量写入return{}中*/return{ str:"123234",boo:true,boo1:false,username:'',pwd:'',sex:'',menu1:["农业新闻","教育新闻","天气新闻"],/** 数组*/menu2:["国际新闻","军事新闻","体育新闻","民生新闻"],aaa:"http://www.baidu.com/s",names:["ff","nn","tt","张三"],objs:[ /**引用数据类型 */{name:'LiMing',age:20,sex:"男"},{name:'XiaoMei',age:20,sex:"女"},{name:'XiaoFei',age:20,sex:"男"}]}
数据调用在Html块中:
<template><div><!-- 调用数据问文本时需要{{ }} 双层大括号嵌套使用 --><a v-bind:class="{cla:boo1}" href="aaa">{{ str }}</a><!-- 使用数组 --><select @change="method1">该部门下的所有员工<option v-for="(e,i) in names " :key="i">{{ e }}</option><!-- //循环for v-for="(e,i) e是循环值 i是下标 --></select><table><tr ><td>编号</td><td>姓名</td><td>年龄</td><td>性别</td></tr> <!--循环引用数据类型 v-on 设置事件,值写方法名 或者直接@+事件 无参数可以不写小括号 --><tr v-for="(e,i) in objs" :key="i" v-on:click="show(e.name)"><td>{{i}}</td><td>{{e.name}}</td><td>{{e.age}}</td><td>{{e.sex}}</td></tr></table></div></template>
4.0Vue中的事件和动态属性
动态属性:
<a v-bind:class="{cla:boo1}" href="aaa">{{ str }}</a>
.cla{color:red;font-size: 20px;
}
v-bind:class="{cla:boo1}"表示动态属性设置:将样式设为动态选择;bool是true则样式显示,反之样式不显示
并且v-bind可以省略简写为:
事件:
<select @change="method1">该部门下的所有员工<option v-for="(e,i) in names " :key="i">{{ e }}</option><!-- //循环for v-for="(e,i) e是循环值 i是下标 --></select><!-- names是含有多个名称的数组 -->
将方法写在JS块中:
<script>
export default {name: 'App', /**1.当前页面名字:App 逗号隔开第二个属性 */data(){/** 2.设置当前页面的显示变量*/
/*想将变量反到前端页面,相当于成员变量,变量写入return{}中*/return{ },methods:{ /**3 设置事件绑定函数 */method1(){alert("选择了新的选项")}}}
</script>
@change="method1" 是v-on:change=“method1” 时间的简写
v-on:可以简写为@
5.0Vue子组件通过导入在主组件显示在网页
子组件:(子组件名为Menu)
<template><div><ul><!-- <li>4三大4</li><li>555</li><li>666</li> --><li v-for="(e,i) in news" :key="i">{{ e }}</li></ul><input type="button" value="传值" @click="method1"></div>
</template>
<script>
export default {name:"Menu",props:{ //5,接受其他组件传来的数据,props中变量名等于其他组件引用时的属性名news:Array},data(){return{str:"我是Menu组件" }},methods:{method1(){this.$emit("getVal",this.str);//$emit 子组件传递数据给主组件方法:第一个参为对方组件事件名,第二个参数为要传递的数据}}
}
</script>
<style></style>
主组件:
<template><div><Menu ></Menu></div>
</template>
<script>// 导入组件
import Menu from './components/Menu.vue'export default {name: 'App', data(){return{ },methods:{ },components:{Menu}}
</script><style type="text/css"></style>
6.0Vue中主组件向子组件传递数据
主组件:
<template><div><Menu :news="menu1" ></Menu>
<!-- news是自定义的子组件的接收到值后的数组名 --></div>
</template>
<script>
import Menu from './components/Menu.vue'
export default {name: 'App', data(){return{ menu1:["农业新闻","教育新闻","天气新闻"]
//将menu1传入子组件},methods:{ },components:{Menu}}
</script><style type="text/css"></style>
子组件:
<template><div><ul><li v-for="(e,i) in news" :key="i">{{ e }}</li></ul></div>
</template>
<script>
export default {name:"Menu",props:{ //5,接受其他组件传来的数据,props中变量名等于其他组件引用时的属性名 :后为所传数据类型news:Array },data(){return{}},methods:{}
}
</script>
<style></style>
6.0Vue子组件向父组件传递数据:
子组件:
<template><div><input type="button" value="传值" @click="method1"></div>
</template>
<script>
export default {name:"Menu",props:{ //5,接受其他组件传来的数据,props中变量名等于其他组件引用时的属性名news:Array},data(){return{str:"我是Menu组件"
//要传递的数据}},methods:{method1(){this.$emit("getVal",this.str);//$emit 子组件传递数据给主组件方法:第一个参为对方组件事件名,第二个参数为要传递的数据}}
}
</script>
<style></style>
主组件:
<template><div><Menu @getVal="getStr"></Menu><!-- getStr是子组件设置的事件名 --></div>
</template>
<script>import Menu from './components/Menu.vue'export default {name: 'App', data(){return{ },methods:{ getStr(str){alert("传递过来的值是"+str)}},components:{Menu}}
</script><style type="text/css"></style>
二.安装node运行环境:
1,下载
双击运行,一直下一步 完成安装 。
关闭终端命令窗口,在打开 输入npm 显示详细信息,就是运行环境安装成功。
2安装vue/cli 脚手架,一键/自动构建项目结构的工具
使用命令:npm install -g @vue/cli
运行如下:

3,创建Vue项目
在想建项目的文件夹上 直接打Cmd进入终端创建
创建vue项目的命令:vue create vue-demo
vue-demo是项目名

按空格是选中,再按空格就是取消选中

2.X
回车安装。


4.运行项目
进到项目所在的文件夹里,启动运行项目!

Local:地址在浏览器打开得到如下图:

5.退出运行状态
Ctrl +C
相关文章:
Vue框架;Vue中的选择和循环结构;Vue数据类型;Vue中的事件和动态属性;Vue子组件通过导入在主组件显示在网页;Vue中主组件向子组件传递数据
一,Vue简介 前端现在比较火的三大框架就是:vue ,React,Angular。在国内使用最多的还是: vue >React >Angular Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的 JavaScript 框架。它基于标准…...
懒人笔记-opencv4.8.0篇
懒人笔记-opencv4.8.0篇 前言1、卸载 opencv3.4.31.1 cmake1.2 编译过程1.3 卸载1.4 检查代码是否卸载干净 2、安装 opencv4.8.02.1 安装依赖2.2 创建编译目录2.3 设置编译选项2.4 执行编译命令2.5 环境配置2.5.1、环境配置添加库路径2.5.2 更新系统2.5.3 配置bash2.5.4 保存退…...
解决uniapp视频video组件进入全屏再退出全屏后,cover-view失效的问题
给cover-view一个变量如isCloseBtnShow,通过v-if(不要用v-show)来控制显示隐藏。监听video全屏事件,全屏时,设置变量为false,退出全屏时再设为true,这样每次退出全屏,cover-view会重新加载。被覆盖的问题就…...
ip属地河北切换北京
我们知道,每当电脑或手机连接网络时,都会分配到一个网络IP地址,这个IP地址通常与设备所在的地区网络相关联。然而,出于业务或个人需求,有时我们需要将本机的IP地址切换到其他城市。例如要将IP属地河北切换北京…...
fpga入门名词(1)
这是第一代FPGA ,在 FPGA(现场可编程门阵列)设计中,LCA(逻辑单元阵列)通常由几个关键组件构成,包括 IOB、CLB 和 Interconnect。以下是这些组件的简要说明: 1. IOB(Input/Output B…...
设计模式-行为型模式-访问者模式
访问者模式难以实现,且应用该模式可能会导致代码可读性变差,可维护性变差,除非必要,不建议使用; 1.访问者模式定义 允许在运行时将一个或多个操作应用于一组对象,将操作与对象结构分离; 访问者…...
探索Oracle数据库的多租户特性:架构、优势与实践
在云计算和大数据时代,多租户架构成为数据库设计中的一个重要趋势。Oracle数据库的多租户选项(Multitenant)允许单个数据库实例支持多个独立数据库(称为容器数据库和可插拔数据库),每个数据库都有自己的数据…...
Hack The Box-Sightless
总体思路 CVE-2022-0944->密码破解->chrome调试->PHP-FPM命令执行 信息收集&端口利用 nmap -sSVC sightless.htbStarting Nmap 7.94SVN ( https://nmap.org ) at 2024-09-11 08:40 CST Nmap scan report for sightless.htb Host is up (0.84s latency). Not sh…...
Linux驱动开发-字符设备驱动开发
linux 驱动开发1. 驱动程序的类型2. 驱动开发流程字符设备驱动 1. 基本概念2. 字符设备驱动的基本结构 架构字符设备驱动开发中常用的 API示例以下代码加入了设备类和设备实例的创建 linux 驱动开发 1. 驱动程序的类型 在 Linux 中,驱动程序主要有以下几种类型&am…...
好用的电脑录屏软件有哪些?推荐4款专业工具。
不同系统的电脑上面带有的录屏功能不一样,比如win10上面有Xbox game bar,Mac系统则用的是QuickTime Player,或者是使用快捷键“CommandShift5”。但更方便的,我自己认为是使用一些专业的录屏软件,他门的录制模式多,兼容…...
web基础之XSS
一、搭建XSS平台 安装 1、我这里安装在本地的Phpstudy上,安装过程就是一路下一步(可以改安装路径),附上下载链接: # 官网:https://www.xp.cn/download.html# 蓝莲花 - github下载 https://github.com/fi…...
目标检测-小目标检测方法
小目标检测是计算机视觉中的一个挑战性问题,因为小目标往往在图像中占据的像素较少,容易被背景或其他物体干扰。为了有效地进行小目标检测,研究人员和工程师提出了多种方法和算法来提高检测精度。以下是一些针对小目标检测的有效方式和算法&a…...
连接数据库(以MySQL为例)
文章目录 前言一、数据库是什么?二、连接步骤 1.手动导入驱动包2.连接数据库总结 前言 面对应用程序的开发,普遍需要保存用户的海量数据。保存粮的库叫粮库,保存水的库叫水库,那么保存数据的库自然叫数据库。有了数据库࿰…...
Mysql高级教程
1.安装部署 安装依赖性: [rootmysql-node10 ~]# dnf install cmake gcc-c openssl-devel ncurses-devel.x86_64 libtirpc-devel-1.3.3-8.el7_4.x86_64.rpm rpcgen.x86_64 下载并解压源码包 [rootmysql-node10 ~]# tar zxf mysql-boost-5.7.44.tar.gz [rootmysql-no…...
基于Ubuntu2404搭建mysql8配置远程访问
使用系统为Ubuntu2404,mysql8版本为8.0.36 安装mysql apt install -y mysql-server设置开机自启动 systemctl enable --now mysql修改密码,似乎是bug,修改密码第一次不成功,第二次可以 mysql use mysql; update user set Host…...
前端工程师职业发展路线图
在前端开发领域,从一个新手成长为一名资深工程师需要经过一系列的学习和实践。以下是一份详细的前端工程师职业发展路线图,包括了从基础到高级的各个阶段。 入门阶段 1. 学习基础技术 HTML/HTML5:掌握网页结构和语义化标签的使用。CSS/CSS…...
人工智能(AI)正在以前所未有的速度融入我们生活的方方面面
人工智能将融入我们生活的方方面面 人工智能(AI)正在以前所未有的速度融入我们生活的方方面面,这种趋势在未来几年乃至几十年内将会持续加速。以下是一些人工智能已经或即将在各个领域产生深远影响的例子: 智能家居:…...
OpenCV-模板匹配多个目标
文章目录 一、基本概念二、基本步骤1.图像准备2.图像预处理3.执行模板匹配4.定位匹配区域5.处理多个匹配6.优化和验证 三、代码实现1.图片读取2.图像预处理3.模板匹配4.绘制矩形框 三、总结 模型匹配(Model Matching)是一个广泛应用的概念,其…...
uniapp 原生插件开发 UI
前言: 在集成某些特定 原生SDK的时候,它本身是带UI控件的。当我们使用 uniapp 开发app的时候实是 可以使使用 nvue 页面,以 weex 的方式嵌入原生的UI控件。 我这边的场景是 接入连连app的支付,它有个自己的密码键盘 控件是原生的页…...
性能测试-性能分析与调优原理总结
性能分析与调优如何下手,先从硬件开始,还是先从代码或数据库。 从操作系统(CPU调度,内存管理,进程调度,磁盘I/O)、网络、协议(HTTP, TCP/IP ),还是…...
StructBERT中文相似度模型GPU算力适配:显存占用峰值218MB,预留缓冲空间充足
StructBERT中文相似度模型GPU算力适配:显存占用峰值218MB,预留缓冲空间充足 1. 项目概述 StructBERT中文相似度计算工具是一个基于百度先进大模型技术的高精度语义匹配系统。这个工具能够智能分析两个中文句子之间的语义相似程度,为各类文本…...
基于RIME-CNN-LSSVM回归模型的优化与预测应用——以MATLAB环境为例
RIME-CNN-LSSVM回归 基于霜冰优化算法优化卷积神经网络(CNN)结合最小二乘向量机(LSSVM)的数据回归预测(可以更换为分类/单、多变量时序预测/回归,前私我),Matlab代码,可直接运行,适合小白新手 程序已经调试好,无需更改…...
红枣切片机的设计【说明书+CAD图纸+solidworks三维+开题报告+答辩PPT】
红枣切片机的设计聚焦于提升切片效率与切片质量,其核心作用在于通过机械结构优化与传动系统设计,实现红枣的自动化、标准化切片加工。设备采用旋转刀盘与固定进料轨道的协同工作模式,刀盘以均匀转速旋转,红枣在重力与轨道约束下依…...
OpenClaw终极指南:GLM-4.7-Flash从入门到精通
OpenClaw终极指南:GLM-4.7-Flash从入门到精通 1. 为什么选择OpenClawGLM-4.7-Flash组合 去年冬天,当我第一次尝试用Python脚本自动化处理日报时,发现传统脚本在面对动态网页和复杂文档时显得力不从心。直到遇见OpenClaw这个能像人类一样操作…...
C 语言从 0 入门(一)|VS2022 完整环境搭建 + 第一个 C 语言程序详解
大家好,我是网域小星球。前面的 Wireshark 抓包实战系列已经全部完结,从本文开始,正式开启一个全新的学习板块:C 语言从 0 到实战入门。 作为网络工程、计算机相关专业的核心基础语言,C 语言贴近计算机底层࿰…...
别再只用Dice Loss了!结合Focal Loss解决钢材缺陷分割中的小目标难题(附PyTorch代码)
突破小目标分割瓶颈:Focal Loss与Dice Loss的黄金组合实践 在工业质检领域,钢材表面缺陷分割任务常面临两个核心挑战:毫米级点状缺陷的漏检与复杂纹理背景下的误报。传统Dice Loss虽能缓解类别不平衡问题,但当遇到像素占比不足0.1…...
30%重复率的论文如何快速合格?爱毕业aibye的AI改写工具提供五条建议
嘿,大家好!我是AI菌。今天咱们来聊聊一个让无数学生头疼的问题:论文重复率飙到30%以上怎么办?别慌,我这就分享5个实用降重技巧,帮你一次搞定,轻松压到合格线以下。这些方法都是我亲身试验过的&a…...
Ubuntu 20.04上解决CARLA报错‘Engine crash handling finished’的保姆级指南(附NVIDIA驱动降级避坑)
Ubuntu 20.04深度调优:彻底解决CARLA引擎崩溃与NVIDIA驱动兼容性问题 当你在Ubuntu 20.04上第一次启动CARLA仿真平台,满心期待地输入./CarlaUE4.sh命令后,终端却突然抛出一连串令人窒息的红色错误信息——"Engine crash handling finish…...
无网环境下的containerd部署实战:从静态二进制到服务就绪
1. 为什么需要离线部署containerd? 在工业控制、军工系统、金融核心业务等特殊场景中,服务器往往运行在物理隔离的网络环境中。我曾经参与过一个智能制造项目,生产线的控制服务器连内网都不允许接入,更别说访问互联网了。这种环境…...
SAMD51平台CAN FD驱动:零拷贝、位定时计算与FreeRTOS集成
1. 项目概述ACANFD_FeatherM4CAN 是专为 Adafruit Feather M4 CAN Express 开发板设计的高性能 CAN FD(Controller Area Network with Flexible Data)驱动库。该库直接面向硬件抽象层,深度适配 SAMD51 微控制器内置的双 CAN FD 模块ÿ…...
