初始vue3

news2025/1/20 21:57:39

如今新vue项目首选用vue3 + typescript + vite + pinia+……模式。在使用Vue2时,使用的是选项式api进行vue项目的开发,vue3在这里做了重大的更新,vue3使用组合式api进行对项目实例化和构建。另外需要注意vue项目需要nodeJS环境的支持,而vue3需要nodeJS的版本最低是node14.18版本,目前最新是node16的版本(奇数版本一般不用),所以在开发vue3项目之前首先需要安装对应的nodeJS环境。

vue2与vue3实例化vue实例对比:

vue2选项式api:

new Vue({
    el: '#app',
    data() {
        return {
            
        }
    },
    methods: {
        
    },
    computed: {
        
    }
})

vue3组合式api:

//生成一个vue实例
var app=Vue.createApp({
    data:function(){
			return{
				msg:"Hello Vue",
				num:0
				}
			},
	methods:{
					
		},
	computed: {
					
		},
});
//app挂载的意思
app.mount("#app");

vue3项目初体验:

这里通过引入vue.js的形式创建一个简单的vue3项目。

vue.js可以通过bootCDN下载。

<div id="app">
	<div>{{msg}}</div>
	<div>{{html}}</div>
	<div v-html="html"></div>
	<div>{{arr.join("-")}}</div>
</div>
<script src="https://cdn.bootcdn.net/ajax/libs/vue/3.2.37/vue.global.prod.js"></script>
<script>
	//生成一个vue实例
	var app=Vue.createApp({
		data:function(){
			return{
				msg:"Hello Vue",
                html:`<h1>HTML指令</h1>`,
				arr:[1,2,3,4,5,6]
				}
			}
		});
		//app挂载的意思
		app.mount("#app");
</script>

v-model数据双向绑定

  1. v-model只能用在表单相关的元素(input、select、 textarea、) 或者自定义组件上

  2. 方向一: 从状态model到view视图(页面中的内容) 状态数据 映射到了视图界面的内容

  3. 方向二: 从view视图 到 状态 model input标签内容随着用户行为进行一个改变,输入的内容同步到状态数据上了

使用典型场景就是表单信息的收集。

案例:

<div id="app">
        <div>{{msg}}</div>
        <div>
            <input type="text" v-model="msg">
        </div>
       <div>
		   <div>{{sex}}</div>
			<label><input type="radio" name="sex" v-model="sex" value="男">男</label>
			<label><input type="radio" name="sex" v-model="sex" value="女">女</label>
			<label><input type="radio" name="sex" v-model="sex" value="保密">保密</label>
       </div>
       <div>
			<div>{{hobby}}</div>
            <label><input type="checkbox" name="hobby" v-model="hobby" value="唱歌">唱歌</label>
            <label><input type="checkbox" name="hobby" v-model="hobby" value="跳舞">跳舞</label>
            <label><input type="checkbox" name="hobby" v-model="hobby" value="打球">打球</label>
       </div>
       <div>
			<div>{{desc}}</div>
			<textarea name="desc" id="" cols="30" rows="10" v-model="desc"></textarea>
       </div>
       <div>
        <div>{{type}}</div>
		<!-- 注意v-model绑定在select标签上 -->
            <select name="type" id="" v-model="type">
                <option value="radio">单选</option>
                <option value="checkbox">多选</option>
                <option value="short">问答</option>
                <option value="long">主观</option>
            </select>
       </div>
    </div>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.2.37/vue.global.js"></script>
    <script>
        var app=Vue.createApp({
            data:function(){
                return{
                    msg:"hello Vue",
                    sex:"男",
                    hobby:[],//复选框  注意是数组
                    desc:"",
                    type:"radio"
                }
            }
        });
        app.mount("#app");
    </script>

注意:按钮类型的标签value必须要写值,否则拿不到对应的值;select下拉列表在进行数据双向绑定的时候v-model写在select标签上。

v-for列表渲染:

<div id="app">
        <div>{{msg}}</div>
        <ul>
            <li v-for="item in arr">{{item}}</li>
        </ul>
		<ul>
		    <li v-for="(item,index) in arr">{{index}}-{{item}}</li>
		</ul>
		<p v-for="val in obj">{{val}}</p>
		<p v-for="(val,key) in obj">{{key}}:{{val}}</p>
		<p v-for="(val,key,index) in obj">{{index}}-{{key}}:{{val}}</p>
		<span v-for="c in msg">{{c}}</span>
		<br>
		<a href="" v-for="item in 10" style="margin-left: 10px;">{{item}}</a>
    </div>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.2.37/vue.global.js"></script>
    <script>
        var app=Vue.createApp({
            data:function(){
                return{
                    msg:"hello Vue",
                    arr:["香蕉","苹果","葡萄","荔枝","桃子"],
					obj:{
						name:"jake",
						age:20,
						sex:"男"
					}
                }
            }
        });
        app.mount("#app");
    </script>

v-for可以循环数字,循环字符串,循环数组及对象。

关于数组和对象中参数顺序的解释:

1.所有的循环,首要目的都是为了获取元素的值

2.其次是元素的键

3.最后是元素的索引

所以v-for的参数第一个是值,第二个是键,第三个是索引。

v-for与v-model综合案例:

<div id="app">
        <div>{{msg}}</div>
        <div>
            <input type="text" v-model="msg" :value="msg">
        </div>
       <div>
		   <div>{{sex}}</div>
        <label v-for="item in sexArr"><input :type="item.type" :name="item.name" v-model="sex" :value="item.value">{{item.label}}</label>
       </div>
       <div>
        <div>{{hobby.join(",")}}</div>
            <label><input type="checkbox" name="hobby" v-model="hobby" value="唱歌">唱歌</label>
            <label><input type="checkbox" name="hobby" v-model="hobby" value="跳舞">跳舞</label>
            <label><input type="checkbox" name="hobby" v-model="hobby" value="打球">打球</label>
       </div>
       <div>
        <div>{{desc}}</div>
        <textarea name="desc" id="" cols="30" rows="10" v-model="desc"></textarea>
       </div>
       <div>
        <div>{{type}}</div>
            <select name="type" id="" v-model="type">
                <option v-for="(item,index) in optionArr" :value="item.value">{{item.label}}</option>
            </select>
       </div>
    </div>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/3.2.37/vue.global.js"></script>
    <script>
        var app=Vue.createApp({
            data:function(){
                return{
                    msg:"hello Vue",
                    sex:"男",
                    hobby:[],
                    desc:"",
                    type:"radio",
					sexArr:[
						{
							type:"radio",
							name:"sex",
							value:"女",
							label:"女"
						},
						{
							type:"radio",
							name:"sex",
							value:"男",
							label:"男"
						},
						{
							type:"radio",
							name:"sex",
							value:"未知",
							label:"未知"
						}
					],
					optionArr:[
						{
							value:"radio",
							label:"单选"
						},
						{
							value:"checkbox",
							label:"多选"
						},
						{
							value:"short",
							label:"问答"
						}
					]
                }
            }
        });
        app.mount("#app");
    </script>

 补充案例:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/408694.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LaTex(1):使用在线表格生成器工具生成LaTex表格

目录 0 在线工具 1 常用命令&#xff1a; 1.0 编辑表格 1.1 Table—set size可以改变表格大小&#xff1a; 1.2 合并表格和拆分表格&#xff1a; 1.3 生成latex代码与复制代码&#xff1a; 2 示例 0 在线工具 表格生成器网页&#xff1a;Create LaTeX tables online –…

BootStrap基本使用

目录 BootStrap框架 BootStrap特点 bootstrap的使用 布局容器 固定宽度 完整宽度 栅格网格系统 前言 列的形式 列组合和列偏移 列排序 列嵌套 排版 标题 段落 强调 对齐效果 列表 去点列表 内联列表 定义列表 代码 表格 表单标签 文本框和文本域 单…

【web服务】nginx为什么这么受企业欢迎?看完这边文章你就懂了

&#x1f4cb; 个人简介 &#x1f496; 作者简介&#xff1a;大家好&#xff0c;我是小鹏linux&#xff0c;运维领域创作者&#xff0c;阿里云ACE认证高级工程师&#x1f61c; &#x1f4dd; 个人主页&#xff1a;小鹏linux&#x1f525; &#x1f389; 支持我&#xff1a;点赞…

【ES6丨前端进阶基础 】ES6的关键字,新特性以及解构赋值

&#x1f482; 个人主页&#xff1a;Aic山鱼 个人社区&#xff1a;山鱼社区 &#x1f4ac; 如果文章对你有所帮助请点个&#x1f44d;吧!欢迎关注、点赞、收藏(一键三连)和订阅专目录 前言 什么是ecmascrpit 一&#xff0c;let关键字的特点 1.不能重复声明变量 2.块级作用…

Http协议之Content-Type理解

Content-Type&#xff0c;翻译过来就是”内容类型“&#xff0c;在互联网中就是”互联网媒体类型“。 在互联网中&#xff0c;两台计算机经常会传输数据&#xff0c;客户端会给服务器发数据&#xff0c;服务器也会给客户端发数据。数据的类型也是有很多种的&#xff0c;我们把所…

【微信小程序系列:四】前端利用wx.setStorageSync缓存设置有效时间

先言&#xff1a; 简单来说&#xff0c;就是利用缓存&#xff0c;进行有效期的保存&#xff0c;以此前端加以判断&#xff0c;在如登录状态过期&#xff0c;操作过期等场景使用&#xff0c;扩展性还蛮多的。 官方文档 实现&#xff1a; 原理&#xff1a;就是先设置一个缓存&…

项目实战 之 vue3 + vite + pinia

目录 一、创建项目 1. 安装vite 2. 创建项目 3. 安装过程 二、项目基本配置 1. 项目icon 2. 项目标题 3. 配置 jsconfig.json 4. 设置 .prettierrc 文件 5. 生成代码片段 01 - 网址 02 - 生成 03 - 配置 04 - 使用 三、项目目录 结构划分 1. assets 2. compo…

require.context()的用法详解

require.context&#xff08;&#xff09;的用法详解&#x1f334;require.context()的介绍&#x1f33a;用法一&#xff1a;在组件内引入多个组件&#x1f33c;用法二&#xff1a;在main.js中引入大量公共组件&#x1f342;用法三&#xff1a;使用插件注册全局组件&#x1f33…

axios+vue 请求时如何携带cookie

axiosvue 请求时如何携带cookie 1&#xff0c;当符合同源策略时&#xff0c;可以直接设置 document.cookie " 你要设置的内容 " mounted() {document.cookie "ioiopipoadiasdasdbasdbas"; // 非跨域传递cookie 直接设置cookie即可this.getData(); /…

Node.js安装,npm安装yarn步骤

第一步&#xff0c;首先安装npm npm是node.js下的包管理器&#xff0c;node.js的下载网址 Node.js 1.下载安装包后一路无脑点击next最后点击finish即可&#xff0c;安装完成之后打开文件夹就是以下目录。 2.在cmd窗口输入node -v、npm -v查看版本检查是否安装成功 一般完成以…

总结JS中常用的数组的方法大全

总结JS中常用的数组方法 JS中常用的数组方法总结 数组(Array)是一种复杂的数据类型&#xff0c;它属于Object(对象)类型&#xff0c;用来将一组数组合在一起&#xff0c;通过一个变量就可以访问一组数据。在使用数组时&#xff0c;经常会搭配循环语句使用&#xff0c;从而很方便…

Vue3+TS+Vite+Element Plus搭建后台管理系统

Vue3TSViteElement Plus搭建后台管理系统1、简介2、效果图3、技术栈4、项目目录5、setting.js(全局配置文件)6、路由router7、状态管理stores8、下载地址总结1、简介 该示例是vue3、typescript、vite、element plus搭建前端管理框架&#xff0c;主要模块分为&#xff1a;菜单、…

用 vite 构建 vue3 + TS 项目实战

目录 1、项目初始化 2、eslint 基础配置 3、配置 git commit hook 4、在开发和构建中进行代码规范校验 5、GitCommit规范 6、 Vite中的TS环境说明 7、Vue3 中 Ts 支持 8、Vue3中的script-setup语法 9、script-setup中的编译宏 10、配置转换JSX和TSX 11、初始化…

vue2计算属性computed

1.什么是计算属性 概念&#xff1a; 1.计算属性是vue的一个特性&#xff0c;此属性有计算能力&#xff0c;也就相当于一个函数。可以将计算结果缓存&#xff0c;作为一个属性使用。 特点&#xff1a; 1.要在 methods: { } 或者 computed&#xff1a; { } 中 &#xff0c;以方…

基于SpringBoot的医疗管理系统(Java毕业设计)

【辰兮要努力】&#xff1a;hello你好我是辰兮&#xff0c;很高兴你能来阅读&#xff0c;昵称是希望自己能不断精进&#xff0c;向着优秀程序员前行&#xff01; 博客来源于项目以及编程中遇到的问题总结&#xff0c;偶尔会有读书分享&#xff0c;我会陆续更新Java前端、后台、…

鲜花商城系统设计与实现(Java+Web+MySQL)

目 录 摘 要 I Abstract II 1 绪论 1 1.1 现状分析 1 1.2 研究意义 1 1.3 研究方法 1 2 系统的开发环境及技术简介 3 2.1 系统开发环境简介 3 2.2 系统开发技术简介 3 3 可行性研究 7 3.1 经济可行性 7 3.2 技术可行性 7 3.3 操作可行性 7 3.4 法律可行性 7 4 需求分析 9 4.1 …

vue+elementui中el-upload组件上传文件时,修改文件名,不用FormData

前言 今天在开发的时候&#xff0c;后端突然提了一个需求&#xff0c;因为特殊的文件上传不进文件服务器&#xff0c;所以后端问我能不能上传的时候给加个扩展名&#xff0c;本着只要逻辑没问题&#xff0c;都可以通过代码实现的理念&#xff0c;我说&#xff1a;“可以“”&a…

攻防世界WEB练习区(backup、cookie、disabled_button)

前言 作者简介&#xff1a;不知名白帽&#xff0c;网络安全学习者。 博客主页&#xff1a;https://blog.csdn.net/m0_63127854?typeblog 攻防世界专栏&#xff1a;https://blog.csdn.net/m0_63127854/category_11983747.html 网络安全交流社区&#xff1a;https://bbs.csdn.ne…

uniApp h5项目通过命令行打包,并生成指定路径、文件名称

需求&#xff1a;想要自动化部署uni项目&#xff0c;平常的uni项目是通过可视化构建&#xff0c;导致我们的自动部署成了半自动&#xff0c;非常不爽&#xff0c;于是就找到了下面这种方法 首先&#xff0c;用hb新建一个项目 然后&#xff0c;通过cli新建一个项目 文档 vue c…

禁止 input 自动填充

禁止 input 自动填充 在编写 Form 表单样式的时候&#xff0c;修改自动填充后的 input 样式是很麻烦甚至不可行的&#xff0c;而且还有一些不需要自动填充的场景。 浏览器根据保存数据时表单控件的 type 和 name 去匹配。 常用的就是 type 为 password&#xff0c;name 为 em…