Elm是一个能够编译成Javascript的函数语言,它可以像React那样作为一个工具用来创建网站或网站应用,Elm 非常简单 易用和优质。

Elm作为函数语言有以下特点:

1.没有运行时的错误,没有null. 没有undefined is not a function.

2.错误信息友好,能够帮助你更快速加入功能。

3.良好架构的代码意味着你的应用代码以良好的构架增长。

4.对所有Elm包自动执行语义版本。.

下面以一个计数器为案例:

import Html exposing (Html, button, div, text)

import Html.App as Html

import Html.Events exposing (onClick)

main =

Html.beginnerProgram { model = 0, view = view, update = update }

type Msg = Increment | Decrement

update msg model =

case msg of

Increment ->

model + 1

Decrement ->

model - 1

view model =

div []

[ button [ onClick Decrement ] [ text "-"]

, div [] [ text (toString model) ]

, button [ onClick Increment ] [ text"+"]

]

注意update和 view是完全解耦的,你可以以声明方式描述你的HTML,而Elm会负责与DOM打交道。

Elm是一个针对无限嵌套组件的简单模式,它非常模块化,易于代码重用和测试,能够帮助你方便创建复杂的Web应用。

每个Elm程序逻辑被划分为三个清晰部分:

Model — 你的应用状态

Update — 更新状态的方式

View — 将状态作为HTML显示的方式

Elm架构是一种简单架构Web应用的模式,类似Redux一样声明,这也是它越来越流行的原因。

这个模式非常可靠,可以下面伪代码说明,每次使用只要填空细节就可以:

import Html exposing (..)

-- MODEL

type alias Model = { ... }

-- UPDATE

type Msg = Reset | ...

update : Msg -> Model -> Model

update msg model =

case msg of

Reset -> ...

...

-- VIEW

view : Model -> Html Msg

view model =

...

Elm 0.17发布以后,引入了消息订阅通过Websocket获得后台状态,只需要两行代码就可以实现和后端服务器交互:

WebSocket.send "ws://echo.websocket.org" input

WebSocket.listen "ws://echo.websocket.org" NewMessage

第一句是向服务器发出数据,第二句是监听服务器的数据,数据内容在NewMessage,NewMessage内容会自动喂给update。

而如果使用Javascript实现这段通讯,将会是非常麻烦,你需要创建一个新的web socket!然后打开一个连接,但是还不能忘记加入对错误的监听,以便连接失败能够重新再连接,并且定义在没有连接时不要发消息(这属于运行错误),你还需要对消息队列化然后再发送,然后确定websocket能被使用并且关闭等等,这些都是涉及大量细节,而声明式编程就应该如上面两行代码直接声明使用,去除了大量技术细节。

elm的 java包_Elm架构相关推荐

  1. elm的 java包_README.md

    #gdelm_manage_java 饿了么后台管理的数据接口程序,只需增加配置,提供数据的增删改查等数据接口 功能: 1.通用功能: 通过文件配置(properties\iface{模块名}\)来提 ...

  2. java更改包名称_更改Java包名称如何改变我的系统架构

    java更改包名称 即使只是少量更改角度,也可能对您如何使用系统产生深远影响. 假设您正在用Java编写Web应用程序. 在系统中,您处理订单,客户和产品. 作为一个Web应用程序,您的类包括诸如Co ...

  3. 更改Java包名称如何改变我的系统架构

    即使只是少量更改角度,也可能对您如何使用系统产生深远影响. 假设您正在用Java编写Web应用程序. 在系统中,您处理订单,客户和产品. 作为Web应用程序,您的类包括诸如Controller,Per ...

  4. 初级Java开发与架构之间的差距不仅仅是开发时间

    转载自  初级Java开发与架构之间的差距不仅仅是开发时间 一.基础篇 JVM JVM内存结构 堆.栈.方法区.直接内存.堆和栈区别 Java内存模型 内存可见性.重排序.顺序一致性.volatile ...

  5. 关于java包_关于Java包

    关于java包 我希望大家都同意,类的方法应该很小,并且只有很少的依赖关系. 这种观点被广泛接受,而对"小"的解释则各不相同. 关于这一点有很多文献. 但是包裹呢? 有些人将包视为 ...

  6. java调用webservice_笃学私教:Java开发网站架构演变过程-从单体应用到微服务架构详解...

    原标题:笃学私教:Java开发网站架构演变过程-从单体应用到微服务架构详解 Java开发网站架构演变过程,到目前为止,大致分为5个阶段,分别为单体架构.集群架构.分布式架构.SOA架构和微服务架构.下 ...

  7. java ejb jsp 架构_JavaEE架构

    B/S 体系结构 image.png Java EE 经典架构 image.png Java EE 13规范 JDBC image.png JDBC 对象与接口 java.sql.DriverMana ...

  8. 【Java】命令行下的Java包结构编译与执行

    编写代码 com.hhh.test.PackageTest package com.hhh.test;public class PackageTest {public static void main ...

  9. Java包名如何命名

    java包起名原则 indi :  个体项目,指个人发起,但非自己独自完成的项目,可公开或私有项目,copyright主要属于发起者.  包名为"indi.发起者名.项目名.模块名.--&q ...

最新文章

  1. android easylink 搜索设备_手把手教你将数据从Android移动到iPhone步骤与技巧
  2. 文件服务器错误用友,用友U8.60用友服务器登陆不了,提示文件错误
  3. k8s minikube管理镜像相关命令:minikube image list/pull/load
  4. java oop入门_java入门(十六) | OOP(三)之构造方法
  5. XXX.C(261): error C100: unprintable character 0xA1/3 skipped
  6. 无法加载一个或多个请求的类型。有关更多信息,请检索 LoaderExceptions 属性
  7. Python之数据分析(规范数据生成器Faker,学习、数据分析、开发测试专用)
  8. 光在参与介质中的传播及辐射传递方程
  9. springBoot整合redis使用介绍(详细案例)
  10. 用单片机测量流体流速的_一种测量管道内流体流速的传感器的制作方法
  11. phpstudy下载、安装、配置、网站部署
  12. 蓝桥杯单片机学习3——数码管静态显示
  13. vuex 是什么? 以及它的基本使用
  14. 选择java版本_新手上路之如何选择Java版本
  15. js实现倒计时,定时器--完成时间倒计时
  16. Android QQ空间(Apad)项目总结(三)---应用UI框架的搭建!!!
  17. 《预测控制》学习记录二-DMC的内模控制结构(IMC)分析
  18. android杀进程管理,还在杀进程?Android你不知道的那些事儿
  19. 解决win10 打开IE 浏览器自动跳转到Edge浏览器
  20. 神经网络算法详解 04:反馈神经网络(Hopfield、BAM、BM、RBM)

热门文章

  1. 颜色(color)、字体(Fonts)管理(颜色的 hex 表示)
  2. python实用技巧(四)
  3. 矩阵等式 matrix identity(numpy仿真)
  4. sci translate好用吗_收藏!SCI论文Introduction 和Conclusion的写作建议
  5. div自动滚动_简易数据分析 10 | Web Scraper 翻页——抓取「滚动加载」类型网页
  6. python爬虫步骤-Python爬虫详解,每一个步骤都给你细腻的讲解(附源码)
  7. python代码翻译器-Python编程学习 -- 用十几行代码实现一个翻译器
  8. python 在线培训费用-线下python培训要多少钱?
  9. 零基础学python电子书-零基础入门学习Python epub高清电子书
  10. python编程入门-Python编程:从入门到实践 PDF 中文扫描版