戳下方图片,输入暗号【面试宝典】即可免费领取107页前端面试题。

js对象 json对象_js循环对象_js 循环生成对象

ASCII(as key)字符集(了解)

我们都知道,计算机只能存储 0101010 这样的二进制数字,那么我们的 a ~ z / A ~ Z / $ / @ /… 之类的内容也有由二进制数字组成的,我们可以简单的理解为, a ~ z / A ~ Z / $ / @ /… 之类的内容都有一个自己的编号,然后在计算机存储的时候,是存储的这些编号,我们看的时候,也是通过这些编号在解析成我们要看到的内容给我们看到

unicode编码

我们看到了,ASCII 只有这 128 个字符的编码结构,但是因为 ASCII 出现的比较早,而且是美国发明的,早先时候这些内容就够用了,因为存储一些英文的内容,传递一些英文的文章什么的都够用了,那么对于这个世界来说肯定是不够用的。

因为我们的汉字没有办法存储,包括一些其他国家的语言也没有办法存储,所以就出现了 unicode 编码,也叫(万国码,统一码),unicode 对照表就是一个和 ASCII 一样的对照表,只不过变得很大很大,因为存储的内容特别的多,而且包含了世界上大部分国家的文字,所以我们的文字和字符现在在存储的时候,都是按照 unicode 编码转换成数字进行存储,我们的 UTF-8 就是一种 8 位的 unicode 字符集

国标编码GBK

国标码是汉字的国家标准编码,目前主要有GB2312、GBK、GB18030三种。

字符串

什么是字符串?

字符串是一种数据类型,字符串就是连续的字符序列js循环对象,由数字,字母和符号组成。在字符串的每个字符只占用一个字节,在 JS内用单引号、 双引号或者反引号(ES6中称为模板字符串)包裹。

什么是包装数据类型

存储的时候, 是以基本数据类型的形式进行存储,当你使用它的时候, 会瞬间转换成 复杂数据类型 的样子让你使用,等你使用完毕, 瞬间转换成 基本数据类型 的形式进行存储,在基本数据类型中有3个特殊的存在:String Number Boolean

这3个基本类型都有自己对应的包装对象。包装对象其实就是对象,有相应的属性和方法。调用方法的过程是在偷偷发生的,所以我们成为基本包装类型

创建字符串

我们创建字符串也分为两种方法 字面量 和 构造函数,字面量:var 变量名 = ‘值’

// 字面量的方式创建字符串
var str = 'hello world'
var str1 = "hello world"
console.log(typeof str)
console.log(typeof str1)

内置构造函数创建

// 内置构造函数的方式创建字符串
var str2 = new String('hello world')
console.log(str2);
console.log(typeof str2);
console.log(str === str1);
console.log(str == str2);

字符串操作

length 属性操作

length属性是一个 只读 的属性, 只能获取不能设置

// 创建一个字符串
var str = 'hello world'
console.log('原始数据 : ', str);
// length 属性
var s1 = str.length
console.log(s1);

索引属性操作

是一个 只读 的属性, 只能获取不能设置

如果有该索引位置, 那么就是该索引位置的字符,如果没有该索引位置, 那么就是 undefinedjs循环对象,索引从0开始,依次加1

// 创建一个字符串
var str = 'hello world'
console.log('原始数据 : ', str);
// 索引
var res = str[4] // 0
console.log(res);
var res1 = str[100]
console.log(res1); // undefined

遍历

// 定义一个字符串
var str = 'hello world'
//  遍历
for (var i = 0; i < str.length; i++) {
    console.log(str[i])
}

案例–统计字符出现的次数

var str = 'abcabcsghgjgfdgdfhfhdsfsdgsh'
// 我们要有个对象
var obj = {}
// 循环遍历该字符串
for (var i = 0; i < str.length; i++) {
    // console.log(str[i]);
    // 我们拿到了字符串中的每一项,我们要把这个当做我们对象的键
    // 因为我们后面要多次用到每一项所以我们可以单独用一个变量接收一下
    var s = str[i]
    // 我们是不是要先看看我们的对象里面有没有这个数据,如果有我们就让它++就好
    // 如果没有我们就给它添加一个
    // 问题来了: 如何判断对象里面有没有,如果对象里面没有这个键 返回的是undefined console.log(obj.a);
    if (obj[s] === undefined) {
        obj[s] = 1
    } else {
        obj[s]++
    }
}
console.log(obj);

近期课程上新:

HTML5+CSS基础|JavaScript|计算机基础

Vue2.0+Vue3.0|微信小程序|微信公众号开发|Node.js|node.JS后端|React基础|React项目|Webpack基础|Webpack高级

Vite2|TypeScript教程|Node.JS|Flutter |Mpvue教程

限时特惠:本站每日持续更新海量设计资源,一年会员只需29.9元,全站资源免费下载
站长微信:ziyuanshu688