vue2脚手架笔记总结1

1.什么是组件

组件是实现局部代码和功能资源的集合

2.vue.config.js配置文件

使用vue inspect > output.js可以查看到Vue脚手架的默认配置,但是在这里面修改不会影响实际的配置,如果需要修改配置需要使用用vue.config.js文件,详情见:https://cli.vuejs.org/zh

3.关于不同版本的Vue

vue的原始版本报班核心功能和模板解析器,但是这样在打包的时候会一起打包上模板解析器,白白多占用1/3的空间,所以对vue进行的拆分

3.1. vue.js与vue.runtime.xxx.js的区别:

(1). vue.js是完整版的Vue,包含:核心功能 + 模板解析器。

(2). vue.runtime.xxx.js是运行版的Vue,只包含:核心功能;没有模板解析器。

3.2. 因为vue.runtime.xxx.js没有模板解析器,所以不能使用template这个配置项,需要使用render函数接收到的createElement函数去指定具体内容。

4.ref属性

4.1. 被用来给元素或子组件注册引用信息(id的替代者)

4.2. 应用在html标签上获取的是真实DOM元素,应用在组件标签上是组件实例对象(vc)

4.3. 使用方式:

(1). 打标识:在html元素或者组件中直接添加,school是自己定义的组件

javascript 复制代码
<h1 ref="xxx"></h1>
<School ref="xxx"></School>

(2). 获取:获取的组件是VueComputed的实例对象,标签就是标签

javascript 复制代码
this.$refs.xxx 

5. props配置项

5.1. 功能:让组件接收外部传过来的数据

5.2. 传递数据:

javascript 复制代码
<Demo name="xxx"/>

5.3. 接收数据:

(1). 第一种方式(只接收):

javascript 复制代码
props:['name'] 

(2). 第二种方式(限制接收类型):

javascript 复制代码
props:{name:String}

(3). 第三种方式(限制类型、限制必要性、指定默认值):

javascript 复制代码
props:{
	name:{
	type:String, //类型
	required:false, //必要性
	default:'张三' //默认值
	}
}

备注:props是只读的,Vue底层会监测你对props的修改,如果进行了修改,就会发出警告,若业务需求确实需要修改,那么请复制props的内容到data中一份,然后去修改data中的数据。(例子:data:{a:this.name})

6.mixin(混入)

  1. 功能:可以把多个组件共用的配置提取成一个混入对象,比如css样式

  2. 使用方式 :

第一步定义混合,创建一个js文件

javascript 复制代码
export const a =   {
                            data(){....},
                            methods:{....}
                            ....
                        }

第二步使用混入:

全局混入:

javascript 复制代码
import { a } from "./mixin"     //引入
Vue.mixin(xxx)                  //使用

​ 局部混入:在script中使用

javascript 复制代码
import { a } from "../mixin"         //引入
mixins:['xxx']                      //使用

7.插件

7.1. 功能:用于增强Vue,比如监视、过滤、自定义指令等功能可以写入到插件中

7.2. 本质:包含install方法的一个对象,install的第一个参数是Vue,第二个以后的参数是插件使用者传递的数据。

7.3. 定义插件:

javascript 复制代码
   对象.install = function (Vue, options) {
                    // 1. 添加全局过滤器
                    Vue.filter(....)

                    // 2. 添加全局指令
                    Vue.directive(....)

                    // 3. 配置全局混入(合)
                    Vue.mixin(....)

                    // 4. 添加实例方法
                    Vue.prototype.$myMethod = function () {...}
                    Vue.prototype.$myProperty = xxxx
}

7.4.使用插件:

javascript 复制代码
Vue.use()

8.scoped样式

让样式在局部生效,防止冲突,当我们多个组件中的样式名称相同时就会引用后引入的组件样式,在style中加入scoped就可以让样式局部生效,互不冲突

javascript 复制代码
<style scoped></style>
相关推荐
web小白成长日记6 小时前
企业级 Vue3 + Element Plus 主题定制架构:从“能用”到“好用”的进阶之路
前端·架构
孙严Pay6 小时前
快捷支付:高效安全的在线支付新选择
笔记·科技·计算机网络·其他·微信
じ☆冷颜〃6 小时前
黎曼几何驱动的算法与系统设计:理论、实践与跨领域应用
笔记·python·深度学习·网络协议·算法·机器学习
APIshop6 小时前
Python 爬虫获取 item_get_web —— 淘宝商品 SKU、详情图、券后价全流程解析
前端·爬虫·python
风送雨6 小时前
FastMCP 2.0 服务端开发教学文档(下)
服务器·前端·网络·人工智能·python·ai
XTTX1106 小时前
Vue3+Cesium教程(36)--动态设置降雨效果
前端·javascript·vue.js
数据皮皮侠AI7 小时前
上市公司股票名称相似度(1990-2025)
大数据·人工智能·笔记·区块链·能源·1024程序员节
LYFlied7 小时前
WebGPU与浏览器边缘智能:开启去中心化AI新纪元
前端·人工智能·大模型·去中心化·区块链
Setsuna_F_Seiei7 小时前
2025 年度总结:人生重要阶段的一年
前端·程序员·年终总结
model20058 小时前
alibaba linux3 系统盘网站迁移数据盘
java·服务器·前端