【JavaScript】45_结构对象与对象的解构

简介: # 1、解构对象数组中可以存储任意类型的数据,也可以存数组,如果一个数组中的元素还是数组,则这个数组我们就称为是二维数组解构对象,方便两数交换数值;可以反向赋值对象,数组可以在解构的同时,进行声明```html <script> const arr = ["孙悟空", "猪八戒", "沙和尚"] let a, b, c // a = arr[0] // b = arr[1] // c = arr[2] ; [a,b,

1、解构对象

数组中可以存储任意类型的数据,也可以存数组,

如果一个数组中的元素还是数组,则这个数组我们就称为是二维数组

解构对象,方便两数交换数值;可以反向赋值对象,数组

可以在解构的同时,进行声明

    <script>
        const arr = ["孙悟空", "猪八戒", "沙和尚"]

        let a,
        b,
        c
        // a = arr[0]
        // b = arr[1]
        // c = arr[2]
        ;
        [a,b,c] = arr;//解构赋值

        let [d,e,f,g] = ['唐僧','白骨精','蜘蛛精','玉兔精']//声明同时解构
        
        // ;[d,e,f,g] = [1,2,3]
        // ;[d,e,f=77,g=10] = [1,2,3]
        ;[d,e,f=43,g=g] = [1,2,3]//直接这样的话,会显得g未定义
        console.log(d,e,f,g)

        let [n1,n2,...n3] = [4,5,6,7] // 解构数组时,可以使用...来设置多余的元素

        function fn(){
            return ['二郎神','猪八戒']
        }

        let [name1,name2] = fn();
        console.log(name1,name2)

        //可以通过解构赋值来快速交换两个变量的值
        let a1 = 10
        let a2 = 20

        //以前的方法,需要一个中间值来交换两数值
        // let temp = a1
        // a1 = a2
        // a2 = temp

        ;[a1,a2] = [a2,a1]//[20,10]

        const arr2 = ['孙悟空','猪八戒']
        ;[arr2[0],arr2[1]] = [arr2[1],arr2[0]]
        console.log(arr2)

        const arr3 = [['孙悟空',18,'男'],['猪八戒',45,'男']]
        for(let stu of arr3){
            for(let v of stu){
                console.log(v)
            }
        }

        let [[name,age,gender],obj] = arr3
        console.log(name,age,gender)
        console.log(obj)
    </script>

2、对象的解构

    <script>
        const obj = {name:'孙悟空',age:18,gender:'男'}

        // let {name,age,gender} = obj // 声明变量同时解构对象

        let name,age,gender
        ;({name,age,gender} = obj)//如果不加小括号的话,会被JS认为是代码块,但是加了小括号之后还需要添加分号,防止JS误认

        let {address} = obj;//没有的属性返回undefined
        console.log(name,age,gender,address)

        let {name: a,age: b,gender: c,address: d='花果山'} = obj
        console.log(a,b,c,d)
</script>
相关文章
|
1天前
|
JavaScript 前端开发
js用Date对象处理时间
以上就是JavaScript中Date对象处理时间的一些基本方法。
5 0
|
1天前
|
JavaScript 前端开发
在JavaScript中,函数原型(Function Prototype)是一个特殊的对象
【5月更文挑战第11天】JavaScript中的函数原型是一个特殊对象,它为所有函数实例提供共享的方法和属性。每个函数在创建时都有一个`prototype`属性,指向原型对象。利用原型,我们可以向所有实例添加方法和属性,实现继承。例如,我们定义一个`Person`函数,向其原型添加`greet`方法,然后创建实例`john`和`jane`,它们都能调用这个方法。尽管可以直接在原型上添加方法,但推荐在构造函数内部定义以封装数据和逻辑。
15 2
|
1天前
|
JavaScript 前端开发
JavaScript 提供了多种方法来操作 DOM(文档对象模型)
【5月更文挑战第11天】JavaScript 用于DOM操作的方法包括获取元素(getElementById, getElementsByClassName等)、修改内容(innerHTML, innerText, textContent)、改变属性、添加/删除元素(appendChild, removeChild)和调整样式。此外,addEventListener用于监听事件。注意要考虑兼容性和性能当使用这些技术。
7 2
|
1天前
|
存储 JavaScript 前端开发
JavaScript对象方法详解
JavaScript对象方法详解
16 1
|
1天前
|
JavaScript
js多维数组去重并使具有相同属性的对象数量相加
js多维数组去重并使具有相同属性的对象数量相加
11 1
|
1天前
|
设计模式 前端开发 JavaScript
AngularJS是一款由Google收购的JavaScript结构框架
【5月更文挑战第2天】AngularJS是Google收购的JavaScript框架,用于构建动态Web应用,基于MVC模式,强调模块化和双向数据绑定。它简化了视图与模型的同步,通过语义化标签和依赖注入提升开发效率。适用于复杂单页面应用(SPA),但不适合DOM操作密集型或性能要求极高的场景。
25 0
|
1天前
|
前端开发 JavaScript 数据安全/隐私保护
前端javascript的DOM对象操作技巧,全场景解析(二)
前端javascript的DOM对象操作技巧,全场景解析(二)
|
1天前
|
移动开发 缓存 JavaScript
前端javascript的DOM对象操作技巧,全场景解析(一)
前端javascript的DOM对象操作技巧,全场景解析(一)
|
1天前
|
XML Web App开发 前端开发
字节FE:JavaScript学习路线图
字节FE:JavaScript学习路线图
8 0