文將推薦七大生產力工具來幫助程序員充分利用JavaScript,并使整個過程更輕松。在現實世界中,JavaScript是最常用和使用最廣泛的編程語言之一。這些JS開發工具不僅為程序員提供了更多可能,還可以幫助他們進行調試,并為HTML5提供重要支持。
這些工具在幾年前并不常見,但現在每個程序員都習慣使用Javascript編程工具來開發或編程。這個工具包可以為開發人員提供非常有用的幫助,因為它可以輕松地編寫和執行代碼,并找到代碼中的問題。
jQuery UI
借助jQuery UI,程序員可以為多個網站應用程序設計自定義用戶界面,還可以減少為不同互動特征和網站小部件編寫的代碼量。 jQuery UI包含多個保持狀態的窗口小部件,因此與通常的jQuery插件相比具有更加獨特的使用數組。所有jQuery UI的小部件都具有相似的模式,因此只要掌握了其中一個,就可以了解全部。
Express JS
Express.js是一個基本框架,允許程序員在Node.js的幫助下開發網站應用程序。它具有非常高的靈活性,對于程序員來說,它是一個高度響應和可靠的開發框架。Express JS非常穩定、具體,程序員可輕松使用。快速JS的一些功能使得它對程序員來說是獨一無二的,非常優先。Express JS主要特征之一是允許程序員以非常可達的方式創建API,同時還提供了一個URL路由器。
Bytescout
使用Bytescout PDF generator SDK,程序員可以創建有豐富圖像和文本的客戶端PDF代碼。該工具有許多可供任何級別開發人員使用的選項,你可以輕松地從畫布或URL添加圖像,繪制符號,線條以及設置頁面方向,旋轉等。
Jx
Jx是用于開發用戶圖形界面的JavaScript庫。Jx有助于向JavaScript提供AJAX支持。它公開地支持GET和POST方法。純文本和JSON是Jx兩種主要支持的返回類型。在GET方法的幫助下,用戶可以將數據傳輸到服務器端腳本。GET方法的一個例子是url.php?.連接解鎖后,POST方法將傳輸數據。
GET方法的語法:
GET方法的示例:
WaveMaker
WaveMaker是一款開源軟件,可用于開發任何類型的網站應用程序,并且有助于部署這些應用程序。新開發的網站應用程序可以通過WaveMaker運行,它也有助于API開發。在WaveMaker的幫助下,開發人員可以減少開發應用程序時可能發生的浪費,并以更快的速度交付產品。由于WaveMaker允許開發人員立即創建應用程序,并且使他們有機會立即進行測試,可能的錯誤和故障將被完全消除。
JSDoc Toolkit
JSDoc Toolkit幫助開發人員輕松地記錄其代碼。所有用JavaScript編寫的代碼都可以在JSDoc Toolkit的幫助下輕松記錄。由具有獨特編碼風格的不同開發人員開發的大規模應用程序可以通過JSDoc Toolkit輕松管理。
JSDOC工具包的語法:
JSDOC工具包的一個例子:
該代碼可以輸入任何JavaScript,不需要任何單獨的文件。
Firebug
Firebug被認為是用于前端調試的最佳Javascript編程工具之一。它有能力在代碼中設置分區,以便開發人員可以方便地瀏覽代碼。對于在Mozilla瀏覽器外工作的開發人員,建議使用Firebug Lite。Firebug Lite本身就是一個JavaScript庫,允許開發人員將其數據庫包含在網頁中,以便可以使用Firebug的某些功能。
所有使用JavaScript編寫的命令都可以被Firebug命令行輕易接受。一旦輸入了JavaScript命令,每個命令的結果都會以超鏈接的形式出現在控制臺中。有與Firebug應用程序相關聯的多個窗口,并且每個窗口顯示應用程序的不同功能。它還讓開發人員看到單個文件的下載時間。它分解多種形式的對象,如JavaScript的文件和圖像,并指出從瀏覽器緩存加載的文件。
TML 5已經成為Web開發者當中最流行的語言之一,“健壯的”語言有很大的生產優質萬維網內容的能力。HTML 5在近三年的增長迅猛,新引入HTML 5的技術更加的優秀。HTML 5技術被現代瀏覽器所支持,如Chrome、Firefox、Internet Explorer等等。而今天,我們將為您推薦十個HTML 5動畫工具,希望對您的工作有所幫助。
Mixeek是一款免費的軟件工具,可用于設計和交互Web動畫。該工具基于JavaScript、CSS和HTML 5。Mixeek是輕量級的、易于使用的,可替代付費動畫工具。
Animatron是一款直觀的設計與發布編輯軟件。你可以使用Animatron來設計內容,如橫幅、信息圖表和創意動畫(針對桌面電腦、移動設備以及任何你可以選擇的設備)。
你可以使用Tumult Hype來創建美麗的HTML 5 Web內容。用其創建的內容是交互的并擁有偉大的動畫功能。你可以在桌面、智能手機和iPad上使用這個框架,它不需要你有編碼知識。
Mugeda是許多創作工具包、廣告商和代理處的首選,來釋放他們的創造力并創建最優質的媒體廣告單元。該工具最知名的是它創建優質廣告單元、橫幅、插頁式廣告、可擴展和迷你游戲的能力。
HTML5 Maker常用于構建滑塊、橫幅以及用最小的努力創建令人印象深刻的圖形。這個工具是免費的,它不要求你有任何特別的編程知識。
Hippo Studios是一個很好的平臺,可以創建強大的動畫、游戲、演示文稿、應用和多媒體網站。使用Hippo Studios創建的項目被大多數瀏覽器和設備支持。
Sencha Space是一個針對基于HTML和JavaScript應用的安全應用環境。該工具幫助組織簡化了應用的開發、安全、維護以及部署到桌面、平板和智能手機。Sencha最出名的地方是它的安全性。
blysk是一款非常有用的動畫工具。它為動畫和Web設計提供了一個很好的平臺,可以為網站和其他互聯網項目構建直觀的動畫。
Radiapp是一款強大的工具,常用于創建運行時的視頻和圖形。它為現代網站提供實時的圖形編輯界面。
Createjs是一個與HTML 5 Canvas元素工作的JavaScript庫。最出名的地方是創建游戲、衍生藝術以及其他的圖形工具。它為我們提供了偉大的圖形經驗。(編譯:陳明)
原文來自:hidimba360
述 | 楊曉兵
編輯 | 伍杏玲
出品 | CSDN(ID:CSDNnews)
編者前記:
編譯器是連接人類世界與機器世界之間的一座橋梁,它可將程序員理解的高級語言,轉換成程序高效執行的機器碼。在 C/C++ 編譯器里,有 VC、Borland C++、GCC、Watcom C/C++ 等國外熱門編譯器,但屬于國內自主研發的編譯器較少。
畢竟開發一款實用的編譯器不易,涉及前端詞法、語法分析、語意分析、大量的編譯優化等工作。而有一支團隊,不惜花費十余年精力完全自主研發出一款 YC 編譯器和 YC 瀏覽器內核。
為何他們不遺余力地自主研發編譯器和瀏覽器內核?這款編譯器有何優點呢?下面由 YC 編譯器的主要作者之一——楊曉兵,來講述這背后十多年來的漫漫研發路。
以下為楊曉兵自述:
初衷:“做一些對軟件行業進步有幫助的東西”
十多年前,我在中國科學院電子學研究所工作,參與設計一些硬件電路。當時我對硬件的興趣遠超軟件,后創業專門從事軟件工作。
我在創業的過程中發現,做此類軟件雖能賺錢,但無論做得怎樣,對軟件科學的進步都無絲毫作用。盡管付出很多,卻無成就感。
操作系統、數據庫、編譯器以及瀏覽器內核是不需要特殊專業知識的、開發難度非常大、最基礎的軟件產品。
我想從這幾種軟件中選擇其中一項來自主研發,雖然不能肯定做出什么成就,但我有希望能做出一些對軟件行業進步有所幫助的東西,使自己不枉踏入軟件這個行業。根據當時的情況,我發現可先從瀏覽器內核下手,于是我除了維護原有產品外,把主要精力都投入到瀏覽器的研發中。
創新將 C 代碼內嵌到 HTML
兩年后,我們研發完成瀏覽器內核的基本功能,如 HTML 的解析和顯示、JavaScript 腳本的執行等。
此時,我們發現 HTML 的標準越來越復雜,導致開發難度越來越大,如果按照這樣的發展,瀏覽器內核將無法走入市場。
于是我重新思考:如果把 C 語言處理成像 JavaScript 腳本嵌入到 HTML 中,用內嵌 C 代碼的 HTML 超文本做軟件的人機交互界面,這款內核應該會有點競爭優勢。
于是我們花費兩年半的時間將標準 C 語言以 JavaScript 相似的方式在 HTML 中執行,并擴展了一個 HTML 標簽:<user>,每個 user 標簽都可以用屬性 src 指定一個 C 源碼文件,user標簽的顯示界面和所有行為都由它的 C 代碼決定。
同時將 C 編譯器做成一個函數,用該函數編譯生成 C 程序的可執行代碼,執行代碼可被存入文件或直接執行。此時,我們將編譯器取名為 YC 編譯器,瀏覽器內核取名為 YC 瀏覽器。
三年又三年,漫漫研發路
隨后,我們繼續完善瀏覽器內核,將其中的一些內核代碼獨立出來用內嵌編譯器動態編譯執行,并將大部分內核源代碼開源。
與此同時,我們又遇到一個問題:YC 編譯器雖然編譯速度較快,生成的卻是字節碼,執行速度慢,而且與原生代碼相互調用(特別是回調函數)的處理相當繁瑣。因此用當時的 YC 編譯器難以勝任開源代碼的編譯工作。
為了解決自編譯瀏覽器內核代碼的問題,我們決定修改 YC 編譯器,使它的字節碼轉換為原生的執行碼,并擴展語法,使之具有少量的 C++ 語法。這個工作持續了三年。
三年后,YC 編譯器功能增多,它提供一個函數像調用動態鏈接庫一樣直接調用 C 源碼中的函數。此時,瀏覽器內核開源部分都可以用 YC 編譯器實時編譯執行了。
我們繼續改進瀏覽器內核,將速度很慢的 JavaScript 字節碼改為二進制原生代碼,使 JavaScript 的執行速度約提高約 100 多倍。同時將瀏覽器內核代碼全部模塊化并開源,每個模塊都用 YC 編譯器動態編譯執行,編譯器的部分源碼也開源(如內嵌匯編編譯器源碼、反匯編源碼、C/C++ 字節碼的執行源碼等),所有的開源代碼均由內嵌的 YC 編譯器自動檢測編譯,動態執行。這個工作大概耗時四年。
開發至此,我想起谷歌和火狐瀏覽器都已開源,為什么不去看看它們的源代碼呢?于是找到這兩個瀏覽器的源碼。
當時由于一些原因,我分析谷歌瀏覽器源碼沒有編譯通過,而火狐的源碼很順利就編譯成功了,于是我就走上了分析火狐源碼之路。
下載的火狐源碼由純 C 代碼和 C++ 代碼兩部分組成,經 Visual C++ 2013 編譯生成一個 xul.dll 文件和一個 firefox.exe 文件。
我首先分析了它的 C 代碼,將所有的輸出函數全部改為類接口,并讓 xul.dll 通過 YC 編譯器函數 YC_cppLoad 進行實時編譯,然后用類接口調用 C 源碼中的函數。這一步進行得很順利,若修改了火狐的 C 代碼,只要重新運行火狐瀏覽器便可生效,無需其它操作。
曾經的辦公桌
接下來開始分析火狐 C++ 代碼。YC 編譯器只實現了少數幾個 C++ 語法,不能編譯火狐 C++ 代碼,故分析起來非常困難。
為什么火狐 C 代碼容易分析,而它的 C++ 代碼難以分析呢?原來我用 YC 編譯器將它的 C 代碼生成匯編代碼文件、變量結構定義文件、宏定義文件和預編譯文件,通過這幾個文件,大大減少了分析難度。
因此我再次決定修改 YC 編譯器,使之完全支持 C++11 標準,因為火狐 C++ 代碼幾乎使用了所有的 C++11 語法特性。先使用 STL 標準模板庫代碼進行編譯器的修改和調試,出乎預料,這個過程竟用了三年時間!之后,我用 YC++ 編譯器開始調試火狐 C++ 代碼。原以為 STL 那么復雜的代碼都可以編譯通過并正確執行,火狐 C++ 代碼應該能很快就編譯通過。沒想到,很多語法細節 STL 沒有用到,而火狐 C++ 源碼用到了。于是又繼續修改 YC 編譯器,對火狐 C++ 的各個模塊進行編譯,這個過程持續了一年多。
雖然 YC 編譯器可以編譯全部火狐 C++ 代碼,但如何生成執行代碼呢?先從主程序 Firefox.cpp 入手,經整理,這個程序可用 YC 編譯器生成執行代碼 Firefox.exe,并能順利運行。
由于火狐 C++ 各模塊耦合緊密,很難拆分,經過一個多月的工作,仍未能將其拆成多個獨立的源碼模塊以便于用 YC 編譯器實時編譯,動態執行,這也許是我對火狐 C++ 源碼的整體結構還不甚清楚之故,只見其樹木不見其森林。
楊曉兵
當我準備對火狐 C++ 代碼進行再一次總體分析時,有個偶然的機會參與到一個學校管理系統的開發中,因原有的管理系統經常出故障,操作極其不方便。盡管沒有開發 Web 服務程序的經歷,但我做的軟件與 Web 服務器有極大關系。
經了解,要開發這種管理系統需要的軟件有:Apache 或 Nginx 服務器,數據庫 MySQL 或其它,編程工具 ASP 或 JSP 或 PHP 等,于是啟發我們自己研發這些工具。YC 的 C/C++ 和 JavaScript 編譯器和 HTML 解析器正好派上用場。
經過一段時間,一個穩定的、可任意擴展的、多線程高并發的 HTTP 服務器就完成了。該服務器處理 YSP 文件生成網頁傳給瀏覽器。
YSP 是我設計的與 ASP、JSP 和 PHP 功能相似的一種網頁編程語言。YC 服務器執行 YSP 文件中的內嵌 C/C++ 或 JavaScript 代碼,生成 HTML 超文本傳給終端設備。工具做好后,不久便做出了管理系統的雛形,這個雛形在發布的 YC 編譯器中可見到。
做了上述這些工作后,我想是時候該寫本書介紹一下 YC 編譯器了,經過一段時間編寫的《YC編譯器—多語言程序設計》(暫名)即將出版。
當我把書完成后,便立即投入64位的C/C++和JavaScript編譯器的開發,目前開發進展順利,已進入測試階段。
編者后記:
三年時間,可將一個呱呱落地的嬰兒變成蹦蹦跳跳的幼兒,可將一名懵懂的職場新人變成沉穩的老兵。而楊曉兵團隊沉下心,迎難而上,花費三年又三年、再一年、兩年、四年的時間只為突破一個個技術難點,最終自研出 YC 編譯器和 YC 瀏覽器內核。
在這過程中,楊曉兵坦言最大的挑戰不僅是技術,還有思維的高度。這期間不僅有大量的研發工作,還為了優化,多次重寫代碼,讓他堅持下來的是想為計算機軟件科學的發展做貢獻的匠心。
目前楊曉兵團隊正在開發 64 位 C/C++ 編譯器,談及未來,楊曉兵表示先在國內推廣,再走向海外。祝福楊曉兵。
YC編譯器傳送門:http://www.ycbro.com
*請認真填寫需求信息,我們會在24小時內與您取得聯系。