web学习笔记(六十八)项目总结

目录

1.如何取到对象的第一项的键名

2.如何在键名不确定的情况下取到对象的第一项的值

3.如何获取对象的长度

4.计算属性和watch监听监听深层数据

5.样式穿透


1.如何取到对象的第一项的键名

可以通过Object.keys将对象转化为一个包含对象所有可枚举属性名的数组,转换后就可以通过索引来取到对应的键名。

javascript 复制代码
// 访问第一项的键
const issukdiv = ref(Object.keys(data.value.productValue)[0])

2.如何在键名不确定的情况下取到对象的第一项的值

javascript 复制代码
// 访问第一项的值
const firstKey = data.value.productValue[issukdiv.value]

我们平常调用对象的某一项时都是直接打点取值,但是当键名不确定,是个变量时,我们就可以通过中括号来取值 ,两者有些许的区别:

  • 中括号运算符总是可以替代点运算符,但点运算符不一定能全部替代中括号运算符(键名不确定时)
  • 中括号运算符可以用字符串变量的内容作为属性名,而点运算符却不可以。
  • 中括号运算符可以用纯数字为属性名,点运算符不能。
  • 中括号运算符可以用js的关键字和保留字作为属性名,点运算符不可以。

3.如何获取对象的长度

因为对象没有.length属性,但是我们可以通过object.keys获得一个包含对象所有键名的数组,然后通过object.keys(obj).length来获取键名数组的长度,这个长度就是对象的长度。

4.计算属性和watch监听监听深层数据

watch对于引用类型,在vue3中默认只能监听第一层的变化,深层数据的变化监听不了但是可以通过设置deep:true来开启深度监听。在 Vue 2 中,watch 默认情况下是不会深度监听对象的变化的。它与 Vue 3 不同,Vue 2 的响应式系统是通过 Object.defineProperty 来实现的,这种方式只能拦截对象的属性访问和修改,而不能深度追踪对象内部属性的变化。但是当深层数据被改变时,计算属性仍然可以重新计算,无需关心数据的层次问题。

5.样式穿透

通常我们在编写代码会设置样式为scoped模式,使得该组件的样式只在本页面生效。但是在使用一些第三方组件的时候,通过内部类名设置样式可能会不生效,因此使用样式穿透,让内部类名突破scoped的限制,从而生效。eg:

css 复制代码
::v-deep(.van-sidebar-item) {
  height: 1.3333rem;
  width: 2.2933rem;
  color: #333;
  font-size: 0.3467rem;
}
相关推荐
CODE202203183 小时前
promptfoo自定义prompt生成器
java·前端·prompt
木木_王3 小时前
嵌入式学习 | STM32裸板驱动开发(Day01)入门学习笔记(超详细完整版|点灯实验 + 库函数代码 + 原理全解)
linux·驱动开发·笔记·stm32·学习
JAVA面经实录9173 小时前
Java架构师最终完整版学习路线图
java·开发语言·学习
叶子野格3 小时前
数据集网站kaggle注册无验证码选项?
学习
222you3 小时前
Claude Code接入DeepSeek-v4模型
java·服务器·前端
i220818 Faiz Ul3 小时前
高校教务|教务管理|基于springboot+vue的高校教务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·高校教务系统
largecode3 小时前
能不能让座机号码显示“XX公司”那样的认证名称?申请号码认证方法
经验分享·笔记·音视频·课程设计·oneapi·segmentfault·微信开放平台
轻口味3 小时前
AI 时代全栈开发破局:TypeScript 生态实战,从入门到部署一站式通关
前端·mongodb·docker·ai·typescript·react·next.js
for_ever_love__4 小时前
UI学习:数据驱动ce l l
学习·ui·ios·objective-c
ZC跨境爬虫4 小时前
跟着MDN学HTML_day_45:(EventTarget接口)
前端·javascript·ui·html·媒体