當(dāng)前位置:
首頁(yè) >
前端技术
> javascript
>内容正文
javascript
看似无参却有参-----JS中的函数传参
生活随笔
收集整理的這篇文章主要介紹了
看似无参却有参-----JS中的函数传参
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
事件event
JS的事件event是一個(gè)非常大的對(duì)象,不管是什么事件,事件的詳情都會(huì)綁定到全局變量event中。這樣做之所以安全,就是因?yàn)镴S是單線程的。
<html><body><h1>天下大勢(shì)為我所控</h1> </body> <script>function $() {if (arguments.length == 1 && arguments[0].constructor.name === "String") {return document.querySelector(arguments[0]) //這里使用arguments傳遞參數(shù)} else {alert("what are you doing ")}}$("h1").onclick = function() {console.log(event)} </script></html>函數(shù)參數(shù)arguments
function f() {console.log(arguments) } f(1, 2, 3, "one", { name: 'w', age: 1 })復(fù)制這段代碼,F12打開(kāi)瀏覽器控制臺(tái),粘貼運(yùn)行即可看到結(jié)果。
arguments是一個(gè)數(shù)組的派生類(lèi),它比數(shù)組多了一個(gè)callee屬性。
arguments參數(shù)像event參數(shù)一樣,也是一個(gè)全局變量,每次函數(shù)的入棧、彈棧操作都會(huì)更新arguments參數(shù),所以arguments參數(shù)是存儲(chǔ)在棧里面的。
獲取當(dāng)前函數(shù)名稱(chēng)
給函數(shù)的祖先Function綁定一個(gè)getName函數(shù)。
Function.prototype.getName=function(){return this.name//如果不嫌麻煩,還可以使用正則表達(dá)式從整個(gè)函數(shù)(包括函數(shù)體)中抽取函數(shù)名稱(chēng)// this.toString().match(/function\s*([^(]*)\(/)[1] } function f(){} f.getName()還可以使用arguments中的callee對(duì)象來(lái)獲取函數(shù)名稱(chēng)。
前端是一門(mén)需要積累的技術(shù),不懂后端的算法工程師不是好前端。
總結(jié)
以上是生活随笔為你收集整理的看似无参却有参-----JS中的函数传参的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: [WP8.1UI控件编程]Windows
- 下一篇: gradle idea java ssm