国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

使用CoffeeScrip優美方式編寫javascript代碼_javascript技巧

來源:懂視網 責編:小采 時間:2020-11-27 21:44:56
文檔

使用CoffeeScrip優美方式編寫javascript代碼_javascript技巧

使用CoffeeScrip優美方式編寫javascript代碼_javascript技巧:JavaScript無疑是在web最偉大的發明之一,幾乎一切網頁動態效果都是基于它豐富的計算能力。而且它的能力在各種新的JavaScript的Engine下也越來越強了,比如Google Chrome用的V8 Engine。 但是由于誕生的太早,有很多語法定義在今天看來有些效率低下了,一些
推薦度:
導讀使用CoffeeScrip優美方式編寫javascript代碼_javascript技巧:JavaScript無疑是在web最偉大的發明之一,幾乎一切網頁動態效果都是基于它豐富的計算能力。而且它的能力在各種新的JavaScript的Engine下也越來越強了,比如Google Chrome用的V8 Engine。 但是由于誕生的太早,有很多語法定義在今天看來有些效率低下了,一些

JavaScript無疑是在web最偉大的發明之一,幾乎一切網頁動態效果都是基于它豐富的計算能力。而且它的能力在各種新的JavaScript的Engine下也越來越強了,比如Google Chrome用的V8 Engine。

但是由于誕生的太早,有很多語法定義在今天看來有些效率低下了,一些更加先進的語法形式,由于歷史原因,沒辦法加入到現在的JavaScript語言中,可以說一種遺憾。

世界上的很多天才都在為構建更好的JavaScript而努力。已經有了很多嘗試,其中最有前途的,無非就是CoffeeScript和TypeScript了。面對CoffeeScript,我有一見如故的感覺;而TypeScript也激發了我極大的興趣。CoffeeScript和TypeScript一樣,都是編譯為JavaScript的語言,它們都增強了JavaScript的表達能力。這篇文章是講CoffeeScript的,TypeScript將放在下一篇再講。

所謂編譯為JavaScript,是指CoffeeScript和TypeScript沒有實現自己的運行時,它們都是編譯為等價的JavaScript代碼,然后放在JavaScript的解釋器上運行。

CoffeeScript

簡潔性

CoffeeScript給人最大的印象就是其簡潔的表達。下面代碼是我從CoffeeScript中文摘抄下來的:

上面的代碼會編譯為等價的JavaScript代碼:

CoffeeScript力求簡潔。其簡潔性首先表現在對一些僅用于語法控制的符號進行了去除。這其中包括:

取消分號

取消var聲明

取消大括號包圍內層代碼,使用縮進取代

函數調用在沒有歧義的情況下可以省略括號

var聲明涉及到復雜又很雞肋的JavaScript變量作用域機制。這部分內容先放著不講。CoffeeScript通過完全取消var聲明機制而使得問題得到簡化。總之,在CoffeeScript世界里,變量不用事先聲明,直接用就是了。而且這種用法基本沒有什么危險。

縮進在CoffeeScript中不僅僅在于美化代碼,其代表了代碼層次的組織,是有特別的含義的。簡單地說就是,不適用大括號包圍內層代碼,而是內層代碼要縮進。不同的縮進代表了不同的代碼層次。形式和內容是一致的。

縮進的例子:

在不引起歧義的情況下,CoffeeScript的函數調用可以省略括號。例如console.log(object)可以簡化為console.log object。所謂引起歧義的一個例子就是無參數的情況下,console.log就不知道是取出函數型屬性log還是調用函數log了。

CoffeeScript的函數表達式也做了極致的精簡精簡。一個單行函數的定義可以這樣:

而多行函數也是通過縮進來組織的。一個空的函數最為簡潔,是這樣:->。

函數的這種簡潔表達使得傳遞回調函數非常便利。一個數組的map可能像這樣就足夠了:

而等效的JavaScript代碼就不能這么馬虎:

增強的表達

CoffeeScript提供了JavaScript所沒有的一些強大的表達語法,這也是被稱為語法糖的東西。在我印象中,這種增強性是很多的,我舉出兩個有代表性的例子:

字符串插值法

列表解析

其中字符串插值法是對現有字符串能力的一種擴充和語法上的簡化;而列表解析就要涉及到觀念上的改變了。前者是一種改良,后者則是一種變革。

字符串插值法

在CoffeeScript的字符串里,可以用#{…}嵌入一個表達式。例如:

"#{ 22 / 7 } is a decent approximation of π"

等價于:

"" + (22 / 7) + " is a decent approximation of π";

插值在這里起到占位的作用,使得動態內容的字符串更容易構建。我想人人都能接受這樣的表達。

列表解析

列表解析是CoffeeScript的世界里的重要一員。它改變了循環的思路。CoffeeScript沒有提供像JavaScript那樣的for循環結構,而是統統轉化為列表解析。一個常規的JavaScript for循環,像下面這樣:

用CoffeeScript實現就是:

food_list = ['toast', 'cheese', 'wine']
eat food for food in food_list #做個小補充,for循環的單條語句的寫法

單單是上面的例子不足以顯示列表解析的強大(卻看到它的簡潔了)。在繼續這個話題之前,我覺得我有必要補充一下另一個涉及到CoffeeScript理念的東西了:一切皆是表達式。

在CoffeeScript世界里,一切語句都是表達式語句,都會返回一個值。函數調用默認會返回最后一條語句的值。if條件結構也會返回值,其返回的是執行的最后一條語句的值。循環結構有些不同,其會將每次循環的結果都保存在一個數組里,作為此循環結構的值。例如下面代碼的list結果就是[5, 4, 3, 2, 1]。

回到列表解析的主題。與while一樣,for結構也是一種循環的表達,其結果也是一個數組。回到先前的例子,下面的小代碼的list結果就是['t', 'c', 'w']。

我們已經看到for循環的each形式

以及它的map形式

下面給出它的filter形式

列表解析的特色的地方在于它改變了我們組織循環的方式和解析數組的模式。這是一種聲明式的編程方法,告訴程序你想要什么而不去關心構建的過程。

類的支持

類是CoffeeScript對JavaScript的一個很重要的補充。JavaScript的原型功能很強大,寫法上又恨別扭。正確地設置原型鏈以實現繼承關系也是個很大的挑戰。CoffeeScript從語法上直接支持類的定義,自然且隱藏細節。

從實現上來說,CoffeeScript的類與JavaScript的構造函數和原型鏈那一套并無二致。所以,理解原型機制也是理解CoffeeScript類的基礎。

關于JavaScript的糟粕

CoffeeScript的另一個目標是從語法層面上直接消除JavaScript的被人詬病的一些糟粕部分。前面已經說過關于分號的部分。關于var聲明的部分。分號的機制暫且不去例會,總之CoffeeScript不用再去寫分號了。

在JavaScript當中,最為人詬病的糟粕部分有兩處,因為它們使用的情況最多而且容易出錯。

全局變量

相等比較

全局變量

JavaScript的作用域規則很復雜,涉及到var聲明機制和變量提升。在JavaScript里,構造一個全局變量是很容易的,有三種方式:

在全局的環境里用var聲明

在函數內用省略var的方式定義

綁定到window的屬性

window.name = 'name';

其中第1種和第2種方式是最常見的錯誤用法。首先不推薦直接在全局環境中編碼,而是應該用一個匿名函數包裹起來,將程序的作用域限制在這個匿名函數中。第二種用法完完全全就是忘記了var聲明。而我在實際的JavaScript編碼中,忘記var聲明是常有的事(就像經常忘記行末補上分號一樣)。

而在CoffeeScript里面就完全沒有這種擔心了。首先,編譯后的JavaScript代碼不會暴露在全局環境里,所有的代碼都是自動包裹在一個匿名函數(function(){ ... })();內。然后,所有的變量都會自動加上var聲明。這就使得不小心污染全局的情況很難發生,除非使用賦值到window上。

相等比較

我們都知道JavaScript有兩種比較運算符:==和===。我們也知道==在使用的過程中會很坑,所以平時都寧愿多打一個字符而使用===。CoffeeScript的只有一種比較運算符==,而它會編譯成JavaScript的===,從而很好地避過了這道坑。

是否該使用CoffeeScript

CoffeeScript簡化和增強了JavaScript的表達能力,盡可能地從語法層面上就能避免JavaScript的一些坑。用它寫代碼,會讓人有更清晰舒適的感覺,而且不容易犯錯。CoffeeScript的初衷就是提供更好的JavaScript。

然而,CoffeeScript與JavaScript是不兼容的。它既不是JavaScript的子集,也不是超集,而是與JavaScript有著顯然不同思路的一種語言。用CoffeeScript編程就必然要轉換觀念,盡管這種觀念更好更自然,但卻是有些固步自封的人望而卻步的主要原因了。

CoffeeScript并不是適合每一個人的。有些人對于用縮進組織代碼層次完全不能接受,也不能接受用箭頭函數表達法。對于他們來說,去掉function關鍵字和大括號的組織怎么看都怎么地不順眼。

列表解析很強大,卻也顯得過于簡潔了。對于習慣了構造冗雜JavaScript程序的人們來說,并不習慣這種表達方式。

總之,是不可強求別人去學習使用CoffeeScript。JavaScript已經足夠強大,只要足夠小心,完全可以使用JavaScript很好地完成工作。對于那些想要嘗試CoffeeScript,我們也要給予鼓勵的態度,他們是求新求變的勇士。CoffeeScript真的值得一試,而且它真的很小巧,完全掌握它不是件困難的事。

對于在團隊推行CoffeeScript,我本人更是持有保守的看法。如果團隊從一開始就使用CoffeeScript還好。如果是要從CoffeeScript轉為JavaScript,就要謹慎行之。一種可行的方式是先嘗試在一個小項目中使用CoffeeScrip,看看效果如何。

對于個人來說,就沒有什么限制了。如果真的喜歡,就去嘗試吧。你可以使用CoffeeScript寫腳本,構建自己的網站,做一些小玩意。

以上內容是小編給大家介紹的使用CoffeeScrip優美方式編寫javascript代碼,希望大家喜歡。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

使用CoffeeScrip優美方式編寫javascript代碼_javascript技巧

使用CoffeeScrip優美方式編寫javascript代碼_javascript技巧:JavaScript無疑是在web最偉大的發明之一,幾乎一切網頁動態效果都是基于它豐富的計算能力。而且它的能力在各種新的JavaScript的Engine下也越來越強了,比如Google Chrome用的V8 Engine。 但是由于誕生的太早,有很多語法定義在今天看來有些效率低下了,一些
推薦度:
標簽: 方法 使用 js
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产美女精品久久久久中文 | 亚洲欧美自拍偷拍 | 国产精品久久久久国产精品 | 亚洲欧美综合 | 精品欧美一区二区三区在线 | 一级毛片免费毛片毛片 | 欧美激情影音先锋 | 国产视频一区二区三区四区 | 国产最新在线视频 | 久久精品一区二区国产 | 国产在线高清不卡免费播放 | 日韩午夜免费电影 | 国产毛片不卡 | 日韩专区亚洲综合久久 | 亚洲国产精品日韩在线 | 中文字幕一区二区三区四区 | 亚洲第一区视频在线观看 | 日韩欧美片 | 日韩不卡一区 | 啪啪网站免费观看 | 国产高清视频 | 中文字幕免费在线播放 | 欧美视频网站在线观看 | 伊人久久国产 | 国产精品第十页 | 最新国产视频 | 久久午夜影院 | 广东东莞一级毛片免费 | 国产区免费 | 成人a毛片免费视频观看 | 亚洲欧美视频一区二区三区 | 国产一区二区免费视频 | 激情一区二区三区 | 国产精品一区二区三区免费 | 精品国产一区二区三区19 | 精品欧美一区二区三区免费观看 | 又粗又硬又大又深又爽动态图 | 国产精品久久久久久久久久久久 | 日本久久精品免视看国产成人 | 国产免费高清视频在线观看不卡 | 一级毛片黄 |