이 글은 자바스크립트 팁에 관련된 정보를 주로 소개하고 있으니, 필요한 친구들이 참고하면 좋을 것 같습니다. 여러분의 프로그래밍 능력을 향상시킬 수 있는 짧고 실용적인 자바스크립트 팁을 알려드리고 싶습니다.
부울 값을 변환하려면 !! 연산자를 사용하세요
때로는 변수가 존재하는지 확인하거나 값에 유효한 값이 있는지 확인하고 다음과 같은 경우 반환해야 합니다. 그것은 진정한 가치가 존재합니다. 이러한 검증을 위해 우리는 매우 편리하고 간단한 !! 연산자를 사용할 수 있습니다. !!변수를 사용하여 변수를 감지할 수 있습니다. 변수 값이 0, null, " ", 정의되지 않음 또는 NaN이면 false를 반환하고, 그렇지 않으면 true를 반환합니다. 예를 들어 다음 예는 다음과 같습니다.
function Account(cash) { this.cash = cash; this.hasMoney = !!cash; } var account = new Account(100.50); console.log(account.cash); // 100.50 console.log(account.hasMoney); // true var emptyAccount = new Account(0); console.log(emptyAccount.cash); // 0 console.log(emptyAccount.hasMoney); // false
이 예에서는 account.cash 값이 0보다 크면 account.hasMoney에서 반환된 값은 true입니다.
+를 사용하여 문자열을 숫자로 변환
이 트릭은 매우 유용하고 매우 간단하며 문자열 데이터를 숫자로 변환할 수 있지만 다음에만 적합합니다. 문자열 데이터, 그렇지 않으면 NaN이 반환됩니다(예:
function toNumber(strNumber) { return +strNumber; } console.log(toNumber("1234")); // 1234 console.log(toNumber("ACB")); // NaN
이는 Date에도 적용됩니다. 이 경우 타임스탬프 번호를 반환합니다:
console.log(+new Date()) // 1461288164385
Union). 조건 연산자
다음과 같은 코드가 있는 경우:
if (conected) { login(); }
위의 예와 같이 변수를 축약하고 &&를 사용하여 함수와 연결할 수도 있습니다. 약어는 다음과 같습니다.
conected && login();
다음 코드에 표시된 것처럼 일부 속성이나 함수가 객체에 존재하는지 감지할 수도 있습니다.
user && user.login();
|| 연산자를 사용합니다.
기호는 ES6의 기본 매개변수 기능을 갖습니다. 이전 브라우저에서 이 기능을 에뮬레이트하려면 || 연산자를 사용하고 기본값을 두 번째 인수로 전달합니다. 첫 번째 매개변수가 false를 반환하면 두 번째 값이 기본값으로 간주됩니다. 다음 예를 들어보세요.
function User(name, age) { this.name = name || "Oliver Queen"; this.age = age || 27; } var user1 = new User(); console.log(user1.name); // Oliver Queen console.log(user1.age); // 27 var user2 = new User("Barry Allen", 25); console.log(user2.name); // Barry Allen console.log(user2.age); // 25
루프의 캐시 배열 길이
이 기술은 매우 간단하지만 대규모 배열을 처리할 때 성능에 영향을 미칩니다. 루프가 매우 커질 것입니다. 기본적으로 모든 사람은 다음과 같이 동기적으로 반복되는 배열을 작성합니다.
for(var i = 0; i < array.length; i++) { console.log(array[i]); }
작은 배열이라면 괜찮습니다. 큰 배열을 다루는 경우 이 코드는 각 반복마다 반복됩니다. 배열이 모두 다시 계산되므로 약간의 지연이 발생합니다. 이 현상을 피하기 위해 array.length 캐시를 만들 수 있습니다:
var length = array.length; for(var i = 0; i < length; i++) { console.log(array[i]); }
다음과 같이 작성할 수도 있습니다:
for(var i = 0, length = array.length; i < length; i++) { console.log(array[i]); }
객체의 속성 감지
필요할 때 이 작은 트릭은 정의되지 않은 함수나 속성의 실행을 피하기 위해 일부 속성의 존재를 확인할 때 유용합니다. 일부 크로스 브라우저 코드를 사용자 정의하려는 경우에도 이 트릭을 사용할 수 있습니다. 예를 들어 document.querySelector()를 사용하여 ID를 선택하고 IE6 브라우저와 호환되게 만들고 싶지만 IE6 브라우저에는 이 함수가 없으므로 이 연산자를 사용하여 함수 존재 여부를 감지하기가 어렵습니다. . 다음 예와 같이 매우 유용합니다.
if ('querySelector' in document) { document.querySelector("#id"); } else { document.getElementById("id"); }
이 예에서는 querySelector 함수가 문서에 없으면 docuemnt.getElementById("id")가 호출됩니다.
배열의 마지막 요소 가져오기
Array.prototype.slice(begin, end)는 시작과 끝 사이의 배열 요소를 가져오는 데 사용됩니다. end 매개변수를 설정하지 않으면 배열의 기본 길이 값이 끝 값으로 사용됩니다. 하지만 일부 학생들은 이 함수가 음수 값도 매개변수로 받아들일 수 있다는 사실을 모르는 경우가 있습니다. 시작 값을 음수로 설정하면 배열의 마지막 요소를 가져올 수 있습니다. 예:
var array = [1,2,3,4,5,6]; console.log(array.slice(-1)); // [6] console.log(array.slice(-2)); // [5,6] console.log(array.slice(-3)); // [4,5,6]
배열 잘림
이 작은 트릭은 주로 배열의 크기를 잠그는 데 사용되며 일부 요소를 삭제하는 데 사용되면 매우 유용합니다. 배열에서. 예를 들어, 배열에 10개의 요소가 있지만 처음 5개의 요소만 필요한 경우 array.length=5로 배열을 자를 수 있습니다. 예:
var array = [1,2,3,4,5,6]; console.log(array.length); // 6 array.length = 3; console.log(array.length); // 3 console.log(array); // [1,2,3]
는
을 모두 대체합니다.String.replace()函数允许你使用字符串或正则表达式来替换字符串,本身这个函数只替换第一次出现的字符串,不过你可以使用正则表达多中的/g来模拟replaceAll()函数功能:
var string = "john john"; console.log(string.replace(/hn/, "ana")); // "joana john" console.log(string.replace(/hn/g, "ana")); // "joana joana"
合并数组
如果你要合并两个数组,一般情况之下你都会使用Array.concat()函数:
var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.concat(array2)); // [1,2,3,4,5,6];
然后这个函数并不适合用来合并两个大型的数组,因为其将消耗大量的内存来存储新创建的数组。在这种情况之个,可以使用Array.pus().apply(arr1,arr2)来替代创建一个新数组。这种方法不是用来创建一个新的数组,其只是将第一个第二个数组合并在一起,同时减少内存的使用:
var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6];
将NodeList转换成数组
如果你运行document.querySelectorAll(“p”)函数时,它可能返回DOM元素的数组,也就是NodeList对象。但这个对象不具有数组的函数功能,比如sort()、reduce()、map()、filter()等。为了让这些原生的数组函数功能也能用于其上面,需要将节点列表转换成数组。可以使用[].slice.call(elements)来实现:
var elements = document.querySelectorAll("p"); // NodeList var arrayElements = [].slice.call(elements); // Now the NodeList is an array var arrayElements = Array.from(elements); // This is another way of converting NodeList to Array
数组元素的洗牌
对于数组元素的洗牌,不需要使用任何外部的库,比如Lodash,只要这样做:
var list = [1,2,3]; console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3]
转换数值的更加的方法
将字符串转换为数字是非常常见的。最简单和最快的(jspref)的方式来实现,将使用+(加)算法。
var one = '1'; var numberOne = +one; // Number 1
你也可以使用-(减号)算法的转换类型并且变成负数值。
var one = '1'; var negativeNumberOne = -one; // Number -1
返回对象的函数能够用于链式操作
当创建面向对象的JavaScript对象的function时,函数返回一个对象将能够让函数可链式的写在一起来执行。
function Person(name) { this.name = name; this.sayName = function() { console.log("Hello my name is: ", this.name); return this; }; this.changeName = function(name) { this.name = name; return this; }; } var person = new Person("John"); person.sayName().changeName("Timmy").sayName(); //Hello my name is: John //Hello my name is: Timmy
给回调函数传递参数
在默认情况下,你无法将参数传给回调函数,如下:
function callback() { console.log('Hi human'); } document.getElementById('someelem').addEventListener('click', callback);
你可以采取JavaScript闭包的优点来给回调函数传参,案例如下:
function callback(a, b) { return function() { console.log('sum = ', (a+b)); } } var x = 1, y = 2; document.getElementById('someelem').addEventListener('click', callback(x, y));
什么是闭包呢?闭包是指一个针对独立的(自由)变量的函数。换句话说,闭包中定义的函数会记住它被创建的环境。了解更多请参阅MDN所以这种方式当被调用的时候,参数X/Y存在于回调函数的作用域内。
另一种方法是使用绑定方法。例如:
var alertText = function(text) { alert(text); }; document.getElementById('someelem').addEventListener('click', alertText.bind(this, 'hello'));
提升
理解提升将帮助你组织你的function。只需要记住,变量声明和定义函数会被提升到顶部。变量的定义是不会的,即使你在同一行中声明和定义一个变量。此外,变量声明让系统知道变量存在,而定义是将其赋值给它。
function doTheThing() { // 错误: notDeclared is not defined console.log(notDeclared); // 输出: undefined console.log(definedLater); var definedLater; definedLater = 'I am defined!' // 输出: 'I am defined!' console.log(definedLater) // Outputs: undefined console.log(definedSimulateneously); var definedSimulateneously = 'I am defined!' // 输出: 'I am defined!' console.log(definedSimulateneously) // 输出: 'I did it!' doSomethingElse(); function doSomethingElse(){ console.log('I did it!'); } // 错误: undefined is not a function functionVar(); var functionVar = function(){ console.log('I did it!'); } }
为了使事情更容易阅读,在函数作用域内提升变量的声明将会让你明确该变量的声明是来自哪个作用域。在你需要使用变量之前定义它们。在作用域底部定义函数,确保代码清晰规范。
希望这些小技巧能在工作中帮助你解决一些麻烦,对你有所帮助。