이 글에서는 JavaScript에 관한 12가지 팁을 공유하겠습니다. 이러한 팁은 실제 작업에서 몇 가지 문제를 해결하는 데 도움이 될 수 있습니다.
관련 학습 권장사항: javascript 비디오 튜토리얼
!!
연산자를 사용하여 부울 값 변환!!
操作符转换布尔值有时候我们需要对一个变量查检其是否存在或者检查值是否有一个有效值,如果存在就返回true
值。为了做这样的验证,我们可以使用!!
操作符来实现是非常的方便与简单。对于变量可以使用!!variable
做检测,只要变量的值为:0
、null
、" "
、undefined
或者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
如果你有一段这样的代码:
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
array.length
这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的。基本上,大家都会写一个这样的同步迭代的数组:
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"); }
在这个示例中,如果document
不存在querySelector
函数,那么就会调用docuemnt.getElementById("id")
。
Array.prototype.slice(begin,end)
用来获取begin
和end
之间的数组元素。如果你不设置end
参数,将会将数组的默认长度值当作end
值。但有些同学可能不知道这个函数还可以接受负值作为参数。如果你设置一个负值作为begin
的值,那么你可以获取数组的最后一个元素。如:
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
个元素,但你只想只要前五个元素,那么你可以通过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()
때로는 변수가 존재하는지 또는 값이 다음과 같은지 확인해야 할 때가 있습니다. 유효한 값이 있으며, 존재하는 경우 true
값을 반환합니다. 이러한 검증을 수행하기 위해 !!
연산자를 사용하여 이를 달성할 수 있는데 이는 매우 편리하고 간단합니다. 변수의 경우 변수 값이 0
, null
, 인 경우 감지를 위해 <code>!!variable
을 사용할 수 있습니다. " " , undefine
또는 NaN
은 false
를 반환하고, 그렇지 않으면 true
를 반환합니다. 예를 들어 다음 예는 다음과 같습니다.
var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.concat(array2)); // [1,2,3,4,5,6];🎜이 예에서는
account.cash
의 값이 0
보다 크면 에서 반환된 값이 account.hasMoney
참
입니다. 🎜🎜문자열을 숫자로 변환하려면 +
를 사용하세요.🎜이 기술은 매우 간단하며 문자열 데이터를 숫자로 변환할 수 있지만 그렇지 않은 경우에만 적합합니다. 다음 예와 같이 NaN
이 반환됩니다. 🎜var array1 = [1,2,3]; var array2 = [4,5,6]; console.log(array1.push.apply(array1, array2)); // [1,2,3,4,5,6];🎜이는
Date
에도 적용됩니다. 이 경우 타임스탬프 번호가 반환됩니다. 🎜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🎜 Union 조건부 연산자🎜다음과 같은 코드가 있는 경우: 🎜
var list = [1,2,3]; console.log(list.sort(function() { Math.random() - 0.5 })); // [2,1,3]🎜변수를 축약하고
&&
를 사용하여 함수와 연결할 수도 있습니다. 다음과 같이 축약됩니다: 🎜rrreee🎜 다음 코드에 표시된 것처럼 일부 속성이나 함수가 객체에 존재하는지 감지할 수도 있습니다. 🎜rrreee🎜||
연산자🎜 사용 ES6의 기본 매개변수 기능입니다. 이전 브라우저에서 이 기능을 에뮬레이트하려면 ||
연산자를 사용하고 기본값을 두 번째 매개변수로 전달하세요. 첫 번째 매개변수에서 반환된 값이 false
인 경우 두 번째 값이 기본값으로 간주됩니다. 다음 예를 들어보세요. 🎜rrreee🎜루프의 캐시 array.length
🎜이 기술은 매우 간단합니다. 대규모 배열 루프를 처리할 때 성능에 미치는 영향은 매우 큽니다. . 기본적으로 모든 사람은 다음과 같이 동기적으로 반복되는 배열을 작성합니다. 🎜rrreee🎜 작은 배열이라면 괜찮습니다. 큰 배열을 다루는 경우 이 코드는 반복할 때마다 다시 초기화됩니다. 이로 인해 약간의 지연이 발생합니다. 이 현상을 피하기 위해 array.length
의 캐시를 만들 수 있습니다: 🎜rrreee🎜다음과 같이 작성할 수도 있습니다: 🎜rrreee🎜객체의 속성 감지🎜필요할 때 이 트릭은 속성이 존재하는지 확인하고 정의되지 않은 함수나 속성의 실행을 피할 때 유용합니다. 일부 크로스 브라우저 코드를 사용자 정의하려는 경우에도 이 트릭을 사용할 수 있습니다. 예를 들어 document.querySelector()
를 사용하여 id
를 선택하고 IE6 브라우저와 호환되게 만들고 싶지만 이 함수는 IE6 브라우저에 존재하지 않습니다. 다음 예와 같이 이 연산자를 사용하여 이 함수가 존재하는지 여부를 감지하는 데 매우 유용합니다. 🎜rrreee🎜이 예에서 document
가 querySelector
함수가 없으면 docuemnt.getElementById("id")
가 호출됩니다. 🎜🎜배열의 마지막 요소 가져오기🎜Array.prototype.slice(begin,end)
는 begin
및 end
를 가져오는 데 사용됩니다. 코드> 사이의 배열 요소. end
매개변수를 설정하지 않으면 배열의 기본 길이 값이 end
값으로 사용됩니다. 하지만 일부 학생들은 이 함수가 음수 값도 매개변수로 받아들일 수 있다는 사실을 모르는 경우가 있습니다. begin
값을 음수로 설정하면 배열의 마지막 요소를 가져올 수 있습니다. 예: 🎜rrreee🎜배열 잘림🎜 이 작은 트릭은 주로 배열의 크기를 잠그는 데 사용됩니다. 배열의 일부 요소를 삭제하는 데 사용되는 경우 매우 유용합니다. 예를 들어, 배열에 10
요소가 있지만 처음 5개 요소만 원하는 경우 array.length=5
를 통해 배열을 자를 수 있습니다. 다음 예와 같습니다: 🎜rrreee🎜Replace all🎜String.replace()
이 함수를 사용하면 문자열이나 정규식을 사용하여 문자열을 바꿀 수 있습니다. 이 함수는 처음 문자열만 바꿉니다. 하지만 정규 표현식에서 /g
를 사용하여 replaceAll()
함수 함수를 시뮬레이션할 수 있습니다. 🎜rrreee🎜배열 병합🎜두 개를 병합하려면 배열의 경우 일반적으로 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]
现在你学会了些有用的JavaScript小技巧。希望这些小技巧能在工作中帮助你解决一些麻烦,或者说这篇文章对你有所帮助。如果你有一些优秀的JavaScript小技巧,欢迎在评论中与我们一起分享。
위 내용은 12가지 필수 JavaScript 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!