电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

10 個最終編譯成 JavaScript 的腳本語言

瀏覽:10日期:2023-11-12 10:17:15

與簡單的網站相比,現代應用程序有更多 不同的需求 。但是,瀏覽器是一個擁有(大部分)固定技術的平臺,而且JavaScript仍然是web應用程序的核心語言;需要在瀏覽器中運行的任何應用程序都必須用該語言實現。

我們都知道JavaScript并不是實現所有任務的最佳語言,當遇到復雜的應用時,它可能就不太適合。為了避免這個問題,已經創建了幾種新的語言和現有語言的變體,它們都生成可以在瀏覽器中運行的代碼,而無需編寫任何JavaScript代碼,也不用考慮語言的局限性。

文中介紹了10個有趣的語言,這些語言都可以轉換成JavaScript代碼在瀏覽器中執行,也可以在Node.js這樣的平臺上執行。

Dart 是一種經典的面向對象語言,其中所有事物都是對象,任何對象都是類的實例(對象也可以充當函數)。它專門用于構建瀏覽器、服務器和移動設備的應用程序。它由谷歌維護,并且是 驅動下一代 AdWords 用戶界面的語言 , 而 AdWords 是給谷歌創造收入的最重要的產品,這本身就是在證明其大規模的力量。

該語言可被翻譯成 JavaScript ,以便在瀏覽器中使用,或者由 Dart VM 直接解釋執行,這也允許你構建服務器應用程序。可以使用 Flutter SDK 創建移動應用程序。

復雜的應用程序還需要一組成熟的庫和專門為此任務而設計的語言特性,而 Dart 包含所有這些庫和特性。一個流行的庫的例子是 AngularDart ,Angular 的 Dart 版本。

它允許你編寫類型安全的代碼,而不會太有侵入性;你可以編寫類型,但你不需要這樣做,因為它們可以被推斷出來。這允許創建快速原型,而不必過度考慮細節,但一旦你的原型可以工作,你可以添加類型以使其更加健壯。

關于虛擬機中的并發編程,Dart 使用所謂的 Isolates 連同它們自己的內存堆,來代替共享內存線程(Dart 是單線程的),使用消息實現通信。 在瀏覽器中,這個事件稍有不同:你并不是創建新的 isolates, 而是創建新的 Workers 。

// Example extracted from dartlang.orgimport ’dart:async’;import ’dart:math’ show Random;main() async { print(’Compute π using the Monte Carlo method.’); await for (var estimate in computePi()) { print(’π ? $estimate’); }}/// Generates a stream of increasingly accurate estimates of π.Stream<double> computePi({int batch: 1000000}) async* { var total = 0; var count = 0; while (true) { var points = generateRandom().take(batch); var inside = points.where((p) => p.isInsideUnitCircle); total += batch; count += inside.length; var ratio = count / total; // Area of a circle is A = π?r2, therefore π = A/r2. // So, when given random points with x ∈ <0,1>, // y ∈ <0,1>, the ratio of those inside a unit circle // should approach π / 4. Therefore, the value of π // should be: yield ratio * 4; }}Iterable<Point> generateRandom([int seed]) sync* { final random = new Random(seed); while (true) { yield new Point(random.nextDouble(), random.nextDouble()); }}class Point { final double x, y; const Point(this.x, this.y); bool get isInsideUnitCircle => x * x + y * y <= 1;}

開始使用Dart

TypeScript

TypeScript 是 JavaScript 的超集;有效的 JavaScript 程序也是有效的 TypeScript 程序,但后者添加了靜態類型。其編譯器也可以充當從 ES2015+ 到當前實現的轉譯器,所以你總能獲得最新的功能。

不同于許多其他語言,TypeScript 保持 JavaScript 的精神完好無缺,只增加了功能來提高代碼的可靠性。這些是類型注釋,以及其他類型相關的功能,使得編寫 JavaScript 更加愉快,這得益于啟用了靜態分析器等專門的工具來幫助重構過程。另外,類型的添加改進了應用程序不同組件之間的接口。

類型推斷受到支持,因此你不必從一開始就編寫所有的類型。你可以編寫快速解決方案,然后添加所有的類型以獲取對代碼的信心。

TypeScript 也支持高級的類型,如 intersection(交集) 類型 、 union(并集、聯合) 類型、 類型別名、 可區分聯合(discriminated union)和類型保護。你可以在 TypeScript 文檔 站點的 高級類型 頁面中查看所有這些類型。

如果你使用 React,則還可以通過添加 React 類型來支持 JSX。

class Person { private name: string; private age: number; private salary: number; constructor(name: string, age: number, salary: number) {this.name = name;this.age = age;this.salary = salary; } toString(): string {return `${this.name} (${this.age}) (${this.salary})`; }}

Elm 是一種純粹的函數編程語言,它編譯成 JS、 HTM L和 CSS。 你可以只使用 Elm 構建一個完整的站點。這使之成為 JavaScript 框架如 React 的一個很好的替代方案。用它構建的應用程序會自動使用虛擬 DOM 庫,使其速度非常快。其一大優點是內置的體系結構,它使你忘記了數據流,而將重點放在數據聲明和邏輯上。

在 Elm 中,所有函數都是純粹的,這意味著它們將總是對給定輸入返回相同的輸出。除非你指定,否則它們不能做任何其他事情。例如,為了訪問遠程 API,你將創建 command (命令)函數來與外界通信,以及創建 subscription (訂閱)以偵聽響應。純粹性的另一點是,值是不可變的;當你需要某樣東西時,你創建新值,而不是修改舊值。

Elm 的采用可以是漸進式的;可以使用 ports (端口) 與 JavaScript 和其他庫進行通信。雖然 Elm 尚未達到版本 1,但它正被用于復雜和大型的應用程序,使其成為復雜的應用程序的可行的解決方案。

Elm 最具吸引力的功能之一是初學者友好的編譯器,不是生成難以閱讀的消息,而是生成代碼,可以幫助你修復你的代碼。如果你在學習該語言,編譯器本身就可以大有助益。

module Main exposing (..)import Html exposing (..)-- MAINmain : Program Never Model Msgmain = Html.program{ init = init, update = update, view = view, subscriptions = subscriptions}-- INITtype alias Model = Stringinit : ( Model, Cmd Msg )init = ( 'Hello World!', Cmd.none )-- UPDATEtype Msg = DoNothingupdate : Msg -> Model -> ( Model, Cmd Msg )update msg model = case msg ofDoNothing -> ( model, Cmd.none )-- VIEWview : Model -> Html Msgview model = div [] [text model]-- SUBSCRIPTIONSsubscriptions : Model -> Sub Msgsubscriptions model = Sub.none

開始使用 Elm

PureScript

PureScript 是由 Phil Freeman 創建的純函數式強類型的編程語言。它旨在給可用的 JavaScript 庫提供強大的兼容性,在精神上類似于 Haskell,但保持 JavaScript 的核心。

PureScript 的一個強項是它的極簡主義。它不包括在其他語言中被認為是必需的功能的任何庫。例如,不是編譯器本身包含生成器和 promises,而是你可以使用特定的庫來完成任務。你可以為所需功能選擇想要的實現,這樣可以在使用 PureScript 時實現高效和個性化的體驗,同時保持生成的代碼盡可能小。

其編譯器的另一個顯著特征就是能夠在保持與 JavaScript 的兼容性的同時, 用庫和工具生成整潔和可讀的代碼。

像其他語言一樣,PureScript 有自己的構建工具叫做 Pulp,可以與 Gulp 進行比較, 但是用于以這種語言編寫的項目。

關于類型系統,與 Elm不同,即另一種 ML 式的語言,PureScript 支持高級類型的功能,如取自 Haskell 的 higher-kinded types(高級類類型) 以及 type classes(類型類), 從而允許創建復雜的抽象。

module Main whereimport Preludeimport Data.Foldable (fold)import TryPureScriptmain = render $ fold [ h1 (text 'Try PureScript!') , p (text 'Try out the examples below, or create your own!') , h2 (text 'Examples') , list (map fromExample examples) ] where fromExample { title, gist } = link ('?gist=' <> gist) (text title) examples = [ { title: 'Algebraic Data Types', gist: '37c3c97f47a43f20c548'} , { title: 'Loops', gist: 'cfdabdcd085d4ac3dc46'} , { title: 'Operators', gist: '3044550f29a7c5d3d0d0'} ]

開始使用 PureScript

CoffeeScript

CoffeeScript 是一種語言,旨在公開 JavaScript 的良好部分,同時提供更整潔的語法并保留語義。雖然該語言的流行度近年來一直在減弱,但它正在改變方向,現在正在獲得一個新的主要版本,為 ES2015+ 的功能提供支持。

你用 CoffeeScript 編寫的代碼被直接翻譯為可讀的 JavaScript 代碼,并保持與現有庫的兼容性。從版本 2 開始,編譯器將產生與最新版本的 ECMAScript 兼容的代碼。例如,每次你使用一個類,你就獲得一個 JavaScript 類。另外,如果你使用 React,也有好消息: JSX 與 CoffeeScript 兼容。

來自:https://www.oschina.net/translate/10-languages-compile-javascript

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 承插管件_不锈钢承插管件_锻钢高压管件-温州科正阀门管件有限公司 | 微水泥_硅藻泥_艺术涂料_艺术漆_艺术漆加盟-青岛泥之韵环保壁材 武汉EPS线条_EPS装饰线条_EPS构件_湖北博欧EPS线条厂家 | 恒温槽_恒温水槽_恒温水浴槽-上海方瑞仪器有限公司 | 福建珂朗雅装饰材料有限公司「官方网站」 | 工业车间焊接-整体|集中除尘设备-激光|等离子切割机配套除尘-粉尘烟尘净化治理厂家-山东美蓝环保科技有限公司 | 贴板式电磁阀-不锈钢-气动上展式放料阀-上海弗雷西阀门有限公司 工业机械三维动画制作 环保设备原理三维演示动画 自动化装配产线三维动画制作公司-南京燃动数字 | 土壤水分自动监测站-SM150便携式土壤水分仪-铭奥仪器 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 中国玩具展_玩具展|幼教用品展|幼教展|幼教装备展 | 分子精馏/精馏设备生产厂家-分子蒸馏工艺实验-新诺舜尧(天津)化工设备有限公司 | 真空乳化机-灌装封尾机-首页-温州精灌 | 微波萃取合成仪-电热消解器价格-北京安合美诚科学仪器有限公司 | 广州各区危化证办理_危险化学品经营许可证代办 | wika威卡压力表-wika压力变送器-德国wika代理-威卡总代-北京博朗宁科技 | 外贸资讯网 - 洞悉全球贸易,把握市场先机 | 智慧旅游_智慧景区_微景通-智慧旅游景区解决方案提供商 | 甲级防雷检测仪-乙级防雷检测仪厂家-上海胜绪电气有限公司 | 专业生产动态配料系统_饲料配料系统_化肥配料系统等配料系统-郑州鑫晟重工机械有限公司 | 四川成人高考_四川成考报名网 | 北京亦庄厂房出租_经开区产业园招商信息平台| 【星耀裂变】_企微SCRM_任务宝_视频号分销裂变_企业微信裂变增长_私域流量_裂变营销 | 石英粉,滑石粉厂家,山东滑石粉-莱州市向阳滑石粉有限公司 | 升降机-高空作业车租赁-蜘蛛车-曲臂式伸缩臂剪叉式液压升降平台-脚手架-【普雷斯特公司厂家】 | 钢托盘,铁托盘,钢制托盘,镀锌托盘,饲料托盘,钢托盘制造商-南京飞天金属13260753852 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 成都珞石机械 - 模温机、油温机、油加热器生产厂家 | 法钢特种钢材(上海)有限公司 - 耐磨钢板、高强度钢板销售加工 阀门智能定位器_电液动执行器_气动执行机构-赫尔法流体技术(北京)有限公司 | 济南网站建设|济南建网站|济南网站建设公司【济南腾飞网络】【荐】 | 煤机配件厂家_刮板机配件_链轮轴组_河南双志机械设备有限公司 | 污泥烘干机-低温干化机-工业污泥烘干设备厂家-焦作市真节能环保设备科技有限公司 | 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | 设定时间记录电子秤-自动累计储存电子秤-昆山巨天仪器设备有限公司 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | 北京发电车出租-发电机租赁公司-柴油发电机厂家 - 北京明旺盛安机电设备有限公司 | 塑木弯曲试验机_铜带拉伸强度试验机_拉压力测试台-倾技百科 | 绿萝净除甲醛|深圳除甲醛公司|测甲醛怎么收费|培训机构|电影院|办公室|车内|室内除甲醛案例|原理|方法|价格立马咨询 | 重庆监控_电子围栏设备安装公司_门禁停车场管理系统-劲浪科技公司 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | ★济南领跃标识制作公司★济南标识制作,标牌制作,山东标识制作,济南标牌厂 | 衬四氟_衬氟储罐_四氟储罐-无锡市氟瑞特防腐科技有限公司 | 全自动端子机|刺破式端子压接机|全自动双头沾锡机|全自动插胶壳端子机-东莞市傅氏兄弟机械设备有限公司 |