前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【如果你要学JS<18>】——数据类型及其内存分配

【如果你要学JS<18>】——数据类型及其内存分配

原创
作者头像
像素人
发布2024-01-01 22:39:42
1810
发布2024-01-01 22:39:42
举报
文章被收录于专栏:如果你要学JS

1.数据类型

1.简单数据类型和复杂数据类型

简单类型又叫做基本数据类型或者值类型,复杂类型又叫做引用类型。

值类型 :简单数据类型/基本数据类型,在存储时变量中存储的是值本身,因此叫做值类型 string , number,boolean,undefined , null

引用类型:复杂数据类型,在存储时变量中存储的仅仅是地址(引用) ,因此叫做引|用数据类型 通过new关键字创建的对象(系统对象、自定义对象) , 如Object、Array、 Date等

1.特殊的null

代码语言:js
复制
    <script>
    var str = null;
    console.log(typeof(str));//返回值为Object,也就是一个空的对象
    // 一般null用在(当前有个变量将要储存为对象,但并未决定放什么,这时候就用null先给这个变量)
    </script>

2.堆和栈

堆栈空间分配区别: 1、栈(操作系统) :由操作系统自动分配释放存放函数的参数值、局部变量的值等。其操作方式类似于数据结构中的栈; 简单数据类型存放到栈里面 2、堆(操作系统) : 存储复杂类型(对象) , - 般由程序员分配释放,若程序员不释放,由垃圾回收机制回收。 复杂数据类型存放到堆里面

简单数据类型内存分配

简单数据类型的值存放到栈里面

复杂数据类型内存分配

例如:var arr = [1,2,3] 先把arr指向栈,然后在里面存放的是arr的地址,而不是值,然后这个地址在指向堆,并且开辟出一个空间给这个地址所指向的值

2.webApi

1.API

1.API ( Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序 与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

2.而Web API是浏览器提供的一套操作浏览器功能和页面元素的API( BOM和DOM)。

2.DOM是啥?

文档对象模型( Document Object Model ,简称DOM) ,W3C组织推荐的处理可扩展标记语言( HTML 或者XML )的标准编程接口。

文档: 一个页面就是一个文档 , DOM中使用document表示 元素:页面中的所有标签都是元素, DOM中使用element表示 节点:网页中的所有内容都是节点(标签、属性、文本、注释等) , DOM中使用node表示

3.如何获取元素?

1.根据ID获取

使用getElementById()

代码语言:html
复制

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <div id="name">像素人</div>
    <script>
        var uname = document.getElementById('name');
        console.log(uname);// 返回一个id的元素对象,若没有次id则返回null
        console.dir(uname);// 可以打印返回的元素对象,更好的查看该元素对象的属性和方法。
    </script>
</body>
</html>

3.根据标签名获取

使用getElementsByTagName(方法可以返回带有指定标签名的对象的集合),以伪数组的形式存储

代码语言:js
复制
    <ol id="shanyu">
        <li>6像素人
是个大帅哥</li>
        <li>7像素人
是个大帅哥</li>
        <li>8像素人
是个大帅哥</li>
        <li>9像素人
是个大帅哥</li>
        <li>0像素人
是个大帅哥</li>
    </ol>
    <script>
        var ol = document.getElementById('shanyu');
        console.log(ol.getElementsByTagName('li'));
    </script>

用for循环依次打印元素对象

代码语言:html
复制
    <ul>
        <li>1像素人
是个大帅哥</li>
        <li>2像素人
是个大帅哥</li>
        <li>3像素人
是个大帅哥</li>
        <li>4像素人
是个大帅哥</li>
        <li>5像素人
是个大帅哥</li>
    </ul>
代码语言:js
复制
    <script>
        // 返回的是获取过来元素对象的集合以伪数组的形式存储的
        // 如果页面中没有此元素,依旧返回一个伪数组,只不过是空的
        var liss = document.getElementsByTagName('li');
        console.log(liss);
        // 依次打印元素对象(得到的元素是动态元素)
        for (var i = 0; i < liss.length; i++) {
            console.log(liss[i]);
        }
    </script>

使用element.getElementsByTagName(),获取某个父元素内得所有子元素

代码语言:js
复制
    <script>
        var ol = document.getElementById('shanyu');
        console.log(ol.getElementsByTagName('li'));
    </script>

注:父元素必须是单个对象(必须指明是哪一个元素对象).获取的时候不包括父元素自己。

4.通过HTML5新增的方法获取

1.getElementsByClassName根据类名获得某些元素集合

2.querySelector返回指定选择器的第一个

3.querySelectorAll根据选择器返回所有指定元素对象集合

代码语言:html
复制
<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
 
<body>
    <div class="box">像素人
大帅哥1</div>
    <div class="box">像素人
大帅哥2</div>
    <ul id="midFestival">
        <li>提前祝大家</li>
        <li>春节快乐!</li>
    </ul>
    <script>
        // getElementsByClassName根据类名获得某些元素集合
        var boxs = document.getElementsByClassName('box');
        console.log(boxs);
        // querySelector返回指定选择器的第一个(类选择器和id选择器都可以用哦)   类选择器(.类名)和id选择器(#id明)。
        var mid = document.querySelector('#midFestival');
        console.log(mid);
        // querySelectorAll根据选择器返回所有指定元素对象集合
        var all = document.querySelectorAll('.box');
        console.log(all);
    </script>
</body>
 
</html>

5.特殊元素获取(body,html)

代码语言:html
复制
<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
 
<body>
    <script>
        // 获取body元素
        var elBody = document.body;
        console.log(elBody);
        console.dir(elBody);// 返回元素对象
    </script>
    <script>
        // 获取html元素
        var ht = document.documentElement;
        console.log(ht);
    </script>
</body>
 
</html>

原创✨:还希望各位大佬支持一下

点赞👍:您的赞赏是我前进的动力!

收藏⭐:您的支持我是创作的源泉!

评论✍:您的建议是我改进的良药!

我正在参与2023腾讯技术创作特训营第四期有奖征文,快来和我瓜分大奖!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.数据类型
    • 1.简单数据类型和复杂数据类型
      • 1.特殊的null
      • 2.堆和栈
  • 2.webApi
    • 1.API
    • 3.根据标签名获取
    • 4.通过HTML5新增的方法获取
    • 5.特殊元素获取(body,html)
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档