2023/09/10

文章目录

    • [1. 使用Vue单页面全局变量注意事项](#1. 使用Vue单页面全局变量注意事项)
    • [2. 伪元素和伪类](#2. 伪元素和伪类)
    • [3. Vue3中定义数组通常使用ref](#3. Vue3中定义数组通常使用ref)
    • [4. Vue Router的 router 和 route](#4. Vue Router的 router 和 route)
    • [5. Vue路由中的query和params的区别](#5. Vue路由中的query和params的区别)
    • [6. vue3defineExpose({})属性不能重命名,方法可以重命名](#6. vue3defineExpose({})属性不能重命名,方法可以重命名)
    • [7. 显卡共享内存的原理](#7. 显卡共享内存的原理)
    • [8. deltaY](#8. deltaY)
    • [9. 快速生成方法注释`/**`+回车](#9. 快速生成方法注释/**+回车)

1. 使用Vue单页面全局变量注意事项

javascript 复制代码
<script>
	let globalVal = 'globalVal'
	function globalFun() {}
	export default {
		data() {
			return {
			}
		}
	}
</script>

在上述代码中,传统写法的定义的变量globalValglobalFun可以在export default { }里使用,但无法在模板里直接绑定和调用,模板里只能绑定data里的变量,调用methods里的方法。

2. 伪元素和伪类

3. Vue3中定义数组通常使用ref

ref和reactive定义数组举例如下:

ref定义数组:

javascript 复制代码
<template>
	<!-- Vue3模板引用使用 -->
	<a-table v-model:dataSource="tableData"></a-table>
</template>
<script>
const tableData = ref([])
const getTableData = async () => {
	const { data } = await getTableDataApi()  // 模拟接口得到表格数据
	tableData.value = data  // 修改
}
</script>

以上我们使用ref定义数组并在模板中引用使用,可以看到ref定义数组与定义基本数据类型没什么差异。

下面我们再看看reactive定义数组

javascript 复制代码
<template>
	<!-- Vue3模板引用使用 -->
	<a-table v-model:dataSource="tableData"></a-table>
</template>
<script>
const tableData = reactive([])
const getTableData = async () => {
	const { data } = await getTableDataApi()  // 模拟接口得到表格数据
	tableData= data  // 修改,错误示例,这样赋值会使tableData失去响应式
}
</script>

需要注意的是,如果使用reactive定义数组,并使用tableData = data这样的方式赋值,会使tableData失去响应式

解决方法如下:

  1. 修改为ref赋值
  2. 使用push方法
  3. 将数组包裹在对象中使用

综上所述,在Vue3中定义数组最好使用ref定义,这样可以避免赋值时失去响应式的问题

4. Vue Router的 router 和 route

$router:是路由的操作对象,只写对象。

javascript 复制代码
// 操作,路由跳转
this.$router.push({
	name: 'hello',
	params: {
		name: 'word',
		age: '11'
	}
})

$route:路由信息对象,只读对象。

javascript 复制代码
// 读取 路由参数信息
this.queryInfo = this.$route.query
this.paramsInfo = this.$route.params

5. Vue路由中的query和params的区别

区别1:

query相当于get请求,页面跳转的时候,可以在地址栏看到请求参数;

而params相当于post请求,参数不会在地址栏中显示。

区别2:

query刷新不会丢失query里面的数据;

params刷新会丢失params里面的数据。

参考博客:Vue Router 的params和query传参的使用和区别【讲的超详细,后半部分的params是路由的一部分相关内容尤为重要,建议多看几遍!!!】

6. vue3defineExpose({})属性不能重命名,方法可以重命名

7. 显卡共享内存的原理

8. deltaY

deltaY属性在向下滚动时返回正值,向上滚动时返回负值,否则为0

javascript 复制代码
// 监听鼠标滚轮事件
window.addEventListener('wheel', (e) => {
    if (e.deltaY > 0) {  // 上滚返回负值 下滚返回正值 否则返回0
		// ...
    }
})

9. 快速生成方法注释/**+回车

javascript 复制代码
    methods: {
        /**
         * 
         * @param {*} type 
         * @param {*} name 
         */
        init(type, name) {
            let arr = [1, 2, 3, 4, 5, 6]
            console.log(arr.reduce((pre, cur) => pre + cur, 0));
        }
    },

或者使用插件koroFileHeader,参考博客koroFileHeader的使用

相关推荐
real 12 分钟前
传输层协议UDP
网络·网络协议·udp
智能化咨询10 分钟前
【Linux】【实战向】Linux 进程替换避坑指南:从理解 bash 阻塞等待,到亲手实现能执行 ls/cd 的 Shell
前端·chrome
Anson Jiang12 分钟前
浏览器标签页管理:使用chrome.tabs API实现新建、切换、抓取内容——Chrome插件开发从入门到精通系列教程06
开发语言·前端·javascript·chrome·ecmascript·chrome devtools·chrome插件
掘金安东尼16 分钟前
黑客劫持:周下载量超20+亿的NPM包被攻击
前端·javascript·面试
剑亦未配妥1 小时前
移动端触摸事件与鼠标事件的触发机制详解
前端·javascript
路由侠内网穿透1 小时前
本地部署 GPS 跟踪系统 Traccar 并实现外部访问
运维·服务器·网络·windows·tcp/ip
喵手4 小时前
玩转Java网络编程:基于Socket的服务器和客户端开发!
java·服务器·网络
徐子元竟然被占了!!6 小时前
实验-基本ACL
网络
ftpeak7 小时前
从零开始使用 axum-server 构建 HTTP/HTTPS 服务
网络·http·https·rust·web·web app
Hello_Embed7 小时前
STM32HAL 快速入门(二十):UART 中断改进 —— 环形缓冲区解决数据丢失
笔记·stm32·单片机·学习·嵌入式软件