javascript - 這兩種JS寫法有什么區別
問題描述
function cs() { var _cs = {};_cs .open_change_customer_p = function (url, url_param) {console.log(url);console.log(url_param);//do something......block_enter_presss(); };function block_enter_presss() {/**屏蔽bootstrap搜索框按enter會刷新,搜索框響應enter鍵 */ } return _cs ;}
function cs() { cs .open_change_customer_p = function (url, url_param) {console.log(url);console.log(url_param);//do something......block_enter_presss(); };function block_enter_presss() {/**屏蔽bootstrap搜索框按enter會刷新,搜索框響應enter鍵 */ } return cs ;}
補充內容:我是在網頁上通過var a=new cs();a.open_change_customer_p ();來使用。然后cs只暴露open_change_customer_p 這個函數上面兩種寫法,是把要暴露的方法掛在新的變量中比較好,還是直接掛在函數名下比較好?
問題解答
回答1:前面那種我見得比較多,后面那種寫法是什么鬼。。
回答2:第二種是不是這樣_cs.open_change_customer_p = function (url, url_param){......}
這兩種的區別就是,第二種這種方法可以被刪除,第一種用 var 定義的不能被刪除,除此以外,貌似沒什么區別了,看個人習慣了,第一種可讀性可能會好一點
回答3:靜態方法為什么不抽出來單獨寫一個函數,而要每次都新建?
回答4:...第一種用法:var cs1 = cs();var cs2 = cs();cs1 和 cs2 是兩個不同的對象, 指向不同的內存空間而第二種會指向同一個空間,就是cs函數本身...會出現的問題就是你聲明了倆變量,改變其中一個,另外一個的值跟著變(var cs1 = cs()這種用法)
如果你是想var cs1 = new cs()的話, 第二種始終控制的是cs函數本身呀...那里的cs應該換成this
第一種好...因為第二種很奇怪...
回答5:功能應該都是能實現相同的功能的
第一種看起來會比較舒服
第二種看起來會比較舒服
如果你是覺得第一種那樣定義不太舒服,你可以這樣子定義
function cs() { this.open_change_customer_p = function (url, url_param) {console.log(url);console.log(url_param);block_enter_presss(); };function block_enter_presss() {/**屏蔽bootstrap搜索框按enter會刷新,搜索框響應enter鍵 */ }}console.log(new cs())回答6:
你第二種方法能實現
var a=new cs();cs.open_change_customer_p ();
這樣的調用? 我很懷疑
相關文章:
1. javascript - 使用form進行頁面跳轉,但是很慢,如何加一個Loading?2. python 計算兩個時間相差的分鐘數,超過一天時計算不對3. docker-compose中volumes的問題4. javascript - 后臺管理系統左側折疊導航欄數據較多,怎么樣直接通過搜索去定位到具體某一個菜單項位置,并展開當前菜單5. docker-machine添加一個已有的docker主機問題6. angular.js - 輸入郵箱地址之后, 如何使其自動在末尾添加分號?7. javascript - ES6規范下 repeat 函數報錯 Invalid count value8. javascript - html5的data屬性怎么指定一個function函數呢?9. html5 - 為什么使使用vue cli 腳手架,post-css 沒有自動對css3屬性自動添加瀏覽器前綴呢?10. javascript - 如何使用nodejs 將.html 文件轉化成canvas
