分享Web前端初学者必备JavaScript技巧_惠州前端培训学校
作者:hz_admin01发布时间:2022-04-20分类:前端开发专业浏览:647
下面惠州北大青鸟老师给大家分享Web前端初学者必备JavaScript技巧,希望对大家有帮助。
1、...过滤唯一值
Set对象类型是在ES6中引入的,配合展开操作 ...一起,我们可以使用它来创建一个新数组,该数组只有唯一的值。
const array = [1, 1, 2, 3, 5, 5, 1]
const uniqueArray = [...new Set(array)];
console.log(uniqueArray); // Result: [1, 2, 3, 5]
在ES6之前,隔离惟一值将涉及比这多得多的代码。
此技巧适用于包含基本类型的数组: undefined, null, boolean, string和 number。 (如果你有一个包含对象,函数或其他数组的数组,你需要一个不同的方法!)
2、与或运算
三元运算符是编写简单(有时不那么简单)条件语句的快速方法,如下所示:
x > 100 ? 'Above 100' : 'Below 100';
x > 100 ? (x > 200 ? 'Above 200' : 'Between 100-200') : 'Below 100';
但有时使用三元运算符处理也会很复杂。 相反,我们可以使用'与' &&和'或' || 逻辑运算符以更简洁的方式书写表达式。 这通常被称为“短路”或“短路运算”。
它是怎么工作的
假设我们只想返回两个或多个选项中的一个。
使用 &&将返回第一个条件为 假的值。如果每个操作数的计算值都为 true,则返回最后一个计算过的表达式。
let one = 1, two = 2, three = 3;
console.log(one && two && three); // Result: 3
console.log(0 && null); // Result: 0
使用 ||将返回第一个条件为 真的值。如果每个操作数的计算结果都为 false,则返回最后一个计算过的表达式。
let one = 1, two = 2, three = 3;
console.log(one || two || three); // Result: 1
console.log(0 || null); // Result: null
例一
假设我们想返回一个变量的长度,但是我们不知道变量的类型。
我们可以使用 if/else语句来检查 foo是可接受的类型,但是这可能会变得非常冗长。或运行可以帮助我们简化操作:
return (foo || []).length
如果变量 foo是true,它将被返回。否则,将返回空数组的长度: 0。
例二
你是否遇到过访问嵌套对象属性的问题? 你可能不知道对象或其中一个子属性是否存在,这可能会导致令人沮丧的错误。
假设我们想在 this.state中访问一个名为 data的属性,但是在我们的程序成功返回一个获取请求之前, data 是未定义的。
根据我们使用它的位置,调用 this.state.data可能会阻止我们的应用程序运行。 为了解决这个问题,我们可以将其做进一步的判断:
if (this.state.data) {
return this.state.data;
} else { return 'Fetching Data';
}
但这似乎很重复。 ' 或' 运算符提供了更简洁的解决方案:
return (this.state.data || 'Fetching Data');
一个新特性: Optional Chaining
过去在 Object 属性链的调用中,很容易因为某个属性不存在而导致之后出现 Cannotreadpropertyxxx ofundefined的错误。
那 optional chaining 就是添加了 ?.这么个操作符,它会先判断前面的值,如果是 null或 undefined,就结束调用、返回 undefined。
例如,我们可以将上面的示例重构为 this.state.data?.()。或者,如果我们主要关注 state 是否已定义,我们可以返回 this.state?.data。
该提案目前处于第1阶段,作为一项实验性功能。 你可以在这里阅读它,你现在可以通过Babel使用你的JavaScript,将 @babel/plugin-proposal-optional-chaining添加到你的.babelrc文件中。
3、转换为布尔值
除了常规的布尔值 true和 false之外,JavaScript还将所有其他值视为 ‘truthy’或‘falsy’。
除非另有定义,否则 JavaScript 中的所有值都是'truthy',除了 0, “”, null, undefined, NaN,当然还有 false,这些都是'falsy'
我们可以通过使用负算运算符轻松地在 true和 false之间切换。它也会将类型转换为“boolean”。
const isTrue = !0;
const isFalse = !1;
const alsoFalse = !!0;
console.log(isTrue); // Result: true
console.log(typeof true); // Result: "boolean"
4、转换为字符串
要快速地将数字转换为字符串,我们可以使用连接运算符 +后跟一组空引号 ""。
const val = 1 + "";
console.log(val); // Result: "1"
console.log(typeof val); // Result: "string"
5、转换为数字
使用加法运算符 +可以快速实现相反的效果。
let int = "15";int = +int;
console.log(int); // Result: 15
console.log(typeof int); Result: "number"
这也可以用于将布尔值转换为数字,如下所示
console.log(+true); // Return: 1
console.log(+false); // Return: 0
在某些上下文中, +将被解释为连接操作符,而不是加法操作符。当这种情况发生时(你希望返回一个整数,而不是浮点数),您可以使用两个波浪号: ~~。
连续使用两个波浪有效地否定了操作,因为 — ( — n — 1) — 1=n+1 — 1=n。 换句话说, ~—16 等于 15。
const int = ~~"15"console.log(int); // Result: 15
console.log(typeof int);
Result: "number"
虽然我想不出很多用例,但是按位NOT运算符也可以用在布尔值上: ~true=-2和 ~false=-1。
6、性能更好的运算
从ES7开始,可以使用指数运算符 **作为幂的简写,这比编写 Math.pow(2,3) 更快。 这是很简单的东西,但它之所以出现在列表中,是因为没有多少教程更新过这个操作符。
console.log(2 ** 3); // Result: 8
这不应该与通常用于表示指数的^符号相混淆,但在JavaScript中它是按位 异或运算符。
在ES7之前,只有以 2为基数的幂才存在简写,使用按位左移操作符 <<
Math.pow(2, n);
2 << (n - 1);2**n;
例如, 2<<3=16等于 2**4=16。
7、快速浮点数转整数
如果希望将浮点数转换为整数,可以使用 Math.floor()、 Math.ceil()或 Math.round()。但是还有一种更快的方法可以使用 |(位或运算符)将浮点数截断为整数。
console.log(23.9 | 0); // Result: 23
console.log(-23.9 | 0); // Result: -23
|的行为取决于处理的是正数还是负数,所以最好只在确定的情况下使用这个快捷方式。
如果 n为正,则 n|0有效地向下舍入。 如果 n为负数,则有效地向上舍入。 更准确地说,此操作将删除小数点后面的任何内容,将浮点数截断为整数。
你可以使用 ~~来获得相同的舍入效果,如上所述,实际上任何位操作符都会强制浮点数为整数。这些特殊操作之所以有效,是因为一旦强制为整数,值就保持不变。
删除最后一个数字
按位或运算符还可以用于从整数的末尾删除任意数量的数字。这意味着我们不需要使用这样的代码来在类型之间进行转换。
let str = "1553";
Number(str.substring(0, str.length - 1));
相反,按位或运算符可以这样写:
console.log(1553 / 10 | 0) // Result: 155
console.log(1553 / 100 | 0) // Result: 15
console.log(1553 / 1000 | 0) // Result: 1
8、类中的自动绑定
我们可以在类方法中使用ES6箭头表示法,并且通过这样做可以隐含绑定。 这通常会在我们的类构造函数中保存几行代码,我们可以愉快地告别重复的表达式,例如 this.myMethod=this.myMethod.bind(this)
import React, { Component } from React;
export default class App extends Compononent {
constructor(props) {
super(props);
this.state = {};
}
myMethod = () => {
// This method is bound implicitly! }
render() {
return (
<>
<div>
{this.myMethod()}
</div>
</>
)
}
};
9、数组截断
如果要从数组的末尾删除值,有比使用 splice()更快的方法。
例如,如果你知道原始数组的大小,您可以重新定义它的 length属性,就像这样
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
array.length = 4;
console.log(array); // Result: [0, 1, 2, 3]
这是一个特别简洁的解决方案。但是,我发现 slice()方法的运行时更快。如果速度是你的主要目标,考虑使用:
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
array = array.slice(0, 4);
console.log(array); // Result: [0, 1, 2, 3]
10、获取数组中的最后一项
数组方法 slice()可以接受负整数,如果提供它,它将接受数组末尾的值,而不是数组开头的值。
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
console.log(array.slice(-1)); // Result: [9]
console.log(array.slice(-2)); // Result: [8, 9]
console.log(array.slice(-3)); // Result: [7, 8, 9]
11、格式化JSON代码
最后,你之前可能已经使用过 JSON.stringify,但是您是否意识到它还可以帮助你缩进JSON?
stringify()方法有两个可选参数:一个 replacer函数,可用于过滤显示的JSON和一个空格值。
console.log(JSON.stringify({ alpha: 'A', beta: 'B' }, null, '\t'));
// Result:
// '{
// "alpha": A,
// "beta": B
// }'
想了解更多关于前端的知识吗?可以来惠州北大青鸟新方舟校区了解一下。
标签:惠州前端培训学校惠州前端基础惠州前端培训北大青鸟IT计算机学校北大青鸟IT软件学校前端北大青鸟IT学校惠州北大青鸟北大青鸟
- 前端开发专业排行
- 标签列表
-
- Java (3694)
- 北大青鸟 (3713)
- 软件开发 (3613)
- JAVA (3413)
- UI设计入门 (2093)
- 惠州北大青鸟 (4375)
- 惠州IT培训 (2558)
- UI设计培训 (2090)
- 惠州UI设计培训 (2095)
- 惠州UI设计培训学校 (2090)
- 惠州计算机软件培训 (6260)
- 惠州计算件软件开发 (6260)
- 惠州计算机软件基础 (6261)
- 惠州计算机JAVA培训 (3574)
- 惠州计算机Java软件开发 (3620)
- 惠州计算机JAVA软件开发 (4645)
- 惠州计算机JAVA软件开发学校 (3338)
- 惠州计算机Java软件开发培训 (3338)
- 北大青鸟IT计算机学校 (5048)
- 北大青鸟IT软件学校 (5062)
- 北大青鸟IT学校 (5059)
- 惠州计算机UI设计软件开发 (2088)
- UI设计基础教程 (2088)
- UI设计是什么 (2088)
- UI设计教程 (2088)
- 网站分类
-
- 计算机教程
- 计算机入门
- 职业学校
- 新闻动态
- 专业课程
- 热门技术
- SEO
- 培训教程
- windows
- linux教程
- 系统集成
- 网站开发
- Html5
- 办公软件
- 师资力量
- 热点问答
- 联系我们
- 计算机学校
- 惠州计算机学校
- 河源计算机学校
- 广州计算机学校
- 深圳计算机学校
- 湛江计算机学校
- 佛山计算机学校
- IT计算机培训信息
- 设计专业
- UI
- 影视特效
- 游戏动漫设计
- Photoshop
- AI设计
- 软件教程
- Java技术
- C语言/C++语言培训
- C#
- Python技术
- PHP
- 数据库
- SQL Server
- 网络教程
- 网络安全
- 网络营销
- 软件专业
- 大数据专业
- 前端开发专业
- 软件测试专业
- Python专业
- 软件实施
- 珠海计算机学校
- 初中生学什么好
- 计算机认证
- 文章归档
-
- 2024年12月 (15)
- 2024年11月 (45)
- 2024年10月 (32)
- 2024年9月 (29)
- 2024年8月 (68)
- 2024年7月 (59)
- 2024年6月 (43)
- 2024年5月 (48)
- 2024年4月 (80)
- 2024年3月 (65)
- 2024年2月 (54)
- 2024年1月 (25)
- 2023年12月 (12)
- 2023年11月 (73)
- 2023年10月 (134)
- 2023年9月 (34)
- 2023年8月 (3)
- 2023年7月 (3)
- 2023年6月 (12)
- 2023年5月 (30)
- 2023年4月 (72)
- 2023年3月 (11)
- 2023年2月 (34)
- 2023年1月 (37)
- 2022年12月 (78)
- 2022年11月 (359)
- 2022年6月 (1193)
- 2022年5月 (570)
- 2022年4月 (1567)
- 2022年3月 (982)
- 2022年2月 (54)
- 2022年1月 (182)
- 2021年9月 (308)
- 2021年8月 (1704)
- 2021年7月 (2423)
- 2021年6月 (1806)
- 2021年5月 (1569)
- 2021年4月 (1380)
- 2021年3月 (1255)
- 2021年2月 (709)
- 2021年1月 (1521)
- 2020年12月 (3626)
- 2020年11月 (1646)
- 2020年10月 (1046)
- 2020年9月 (592)
- 最近发表
-
- 东莞信息:2024年长安镇技能创业咖啡节成功举办|||广州计算机软件培训
- 河源信息:本周六百企万岗职等你来市县镇联动大型招聘活动即将开幕!|||计算机培训学校招生
- 茂名信息:茂名组织劳动人事仲裁案件庭审观摩活动|||大学生计算机培训学校
- 茂名信息:茂名市人力资源和社会保障局相继开展诚信宣传四进主题实践活动|||广州市北大青鸟计算机职业培训学校
- 茂名信息:凝心聚力共筑平安茂名市人力资源和社会保障局开展平安建设暨一感两度宣传活动|||大学生计算机培训学校
- 汕头信息:汕头市人力资源和社会保障局开展宪法宣传周活动|||北大青鸟计算机培训中心
- 梅州信息:梅州市人社局开展2024年第四季度诚信文化主题宣传志愿服务活动|||电脑计算机编程培训学校
- 东莞信息:塘厦人社分局联合消防大队开展技工学校等机构消防安全培训|||广州计算机软件培训
- 东莞信息:塘厦塘厦镇成功举办优才服务区第二期业务提升培训班|||计算机软件培训学校
- 东莞信息:2024年横沥镇举办模具设计师职业技能大赛|||广州计算机软件培训