写点什么

Basecamp 发布 JavaScript 框架 Stimulus 1.0

  • 2018-02-21
  • 本文字数:1704 字

    阅读完需:约 6 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

Basecamp 全新推出 Stimulus 1.0,该产品强调 HTML 页面上 JavaScript 轻量级的实现,取代了固有的全功能 JavaScript 应用程序。

Basecamp 称其为“你所拥有的最适用于 HTML 的 JavaScript 框架”。

在 Stimulus 推出之前,Basecamp 团队尝试使用了一系列的技术和库(例如 jQuery)来搭建 Basecamp,但他们并没有获得一个比较全面的解决方案,并且他们发现自己的代码库中有太多不同的模式,很难实现一致性、复用性,对于新入职的团队成员来说很难上手。Basecamp 团队认为大多数现代的框架和 Basecamp 需要解决的问题相违背,它们大多数强调 HTML,而 JavaScript 仅仅起到辅助作用,可是 Basecamp 恰恰相反。

单页面 JavaScript 应用程序提供了更及时的用户交互反馈,在页面加载之间不会白屏,并在内存中保存了 JavaScript 库,因此受到了越来越多的欢迎。Stimulus 旨在通过搭建库 Turbolinks 来保持单页面应用程序的优势,Turbolinks 库可以通过后台持续过程的 HTTP 请求拦截链接,并加载新的 HTML 视图。Turbolinks 起源于 pjax ,pjax 是由 GitHub 开发的。和大多数框架不同的是,Stimulus 加载来自服务器的新 HTML 片段,而不是在客户端将 JSON 数据转换为新的 HTML。

与大多数通用或同构的 JavaScript 框架有所不同,Stimulus 重点仍然加载新的 HTML 视图,而大多数同构的框架仅使用服务器端呈现初始页面视图。

Stimulus 发布强调了三个主要的方面:控制器、动作和目标,并不断增强 HTML 上这些功能。开发人员可以在 HTML 配置一些自定义属性:

复制代码
<!--HTML from anywhere-->
<div data-controller="hello">
<input data-target="hello.name" type="text">
<button data-action="click->hello#greet">
Greet
</button>
<span data-target="hello.output">
</span>
</div>

然后写一个控制器作用于 HTML:

复制代码
// hello_controller.js
import { Controller } from "stimulus"
export default class extends Controller {
static targets = [ "name", "output" ]
greet() {
this.outputTarget.textContent =
`Hello, ${this.nameTarget.value}!`
}
}

Basecamp CTO 兼 Ruby on Rails 创造者 David Heinemeier Hansson 称

Stimulus 关注于如何处理现有的 HTML 文档。有时候这就是增加一个 CSS 类,可以隐藏、动画或强调一个元素。有时候这就是重新以组排列元素。有时候这就是操作元素的内容,比如转换 UTC 时间为本地时间,并显示本地时间。

有时候你希望用 Stimulus 来创建新的 DOM 元素,当然你可以这样做。在未来,我们甚至会开发新的功能让它变得更加简单。但这只是少数人的用例,重点还是在操作而不是创建元素。

从很多方面来说,Stimulus 可以说是回到了十年前,当框架不能完全控制 web 应用程序的时候,创建并渲染 DOM 并追踪状态。它旨在为需要逐步增强的内容网站服务,而不是为已成熟的 JavaScript web 应用程序服务。

HOOQ 的软件工程师 Zufrizal Yordan在 Twitter 评论

我喜欢 Stimulus 的原因是其逐渐增强,而不是通过 JS 为 UI 服务,有时候这样做比较容易。不同的人,不同的方法。很高兴在现在的大环境下能有一款产品不提供完全的 JS。

和一些小的 JavaScript 框架不同的是,Stimulus 是由 TypeScript 编写的。

Basecamp 团队选择 TypeScript 有几个原因,包括适宜的类型注解、工具、重构、防止错误产生、类、代码完善和内嵌文档。Basecamp 工程师 Sam Stephenson 向 InfoQ 解释了使用 TypeScript 的好处:

首先,无论我写不写,这些类型都在我的代码中。TypeScript 的可选注解让编辑和重构过程变得更加适宜。我不喜欢使用类似 Cocoa 风格的委托接口紧耦合地组合类。TypeScript 的接口系统在这里很实用,因为编译器和编辑器会在实现的时候给我列出很多待写的方法。

Stimulus 基于 MIT 开源协议,可以在GitHub 上下载使用。

查看英文原文: Basecamp Releases Stimulus 1.0 JavaScript Framework


感谢罗远航对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2018-02-21 18:001627
用户头像

发布了 218 篇内容, 共 71.8 次阅读, 收获喜欢 76 次。

关注

评论

发布
暂无评论
发现更多内容

100+款AI产品薅羊毛攻略(中)——1年节省大几百万

夏夜许游

AI 视觉智能 阿里云视觉智能开放平台 薅羊毛

智慧屏也常用常新,华为智慧屏V98等6款设备可升级HarmonyOS 3正式版

极客天地

云时代下,医药行业管理居然这么简单

华为云开发者联盟

数据库 华为云 SaaS医药管理系统

一键开启云原生网络安全新视界

京东科技开发者

云原生 网络安全 软件架构 应用结构

6个tips缓解第三方访问风险

SEAL安全

安全 访问权限 第三方访问

Java程序员在写 SQL 时常犯的错误

@下一站

学习 程序媛 Java core 11月月更

Serverless Devs 重大更新,基于 Serverless 架构的 CI/CD 框架:Serverless-cd

Serverless Devs

云计算 Serverless Serverless Devs

想搞懂持续交付理论和实践,你只差这三个问题

华为云开发者联盟

云计算 云原生 华为云 代码托管

代码质量与安全 | “吃狗粮”能够影响到代码质量?来了解一下!

龙智—DevSecOps解决方案

代码质量 代码安全 静态代码安全

vivo霍金实验平台设计与实践-平台产品系列02

vivo互联网技术

A/B 测试 平台化 AB实验

NFTScan 正式推出「NFTScan as a Service」NaaS 服务

NFT Research

NFT 数据基础设施

toB应用私有化交付发展历程、技术对比和选型

北京好雨科技有限公司

阿里云存储负责人吴结生:重新定义下一代云存储

云布道师

云存储 云栖大会

ITSM | 企业如何管理变更、响应事件以及创立知识库——专访龙智技术专家与顾问

龙智—DevSecOps解决方案

阿里云无影研发负责人任晋奎:端云技术创新,打造全新用户体验

云布道师

云栖大会 无影云电脑

Spring Boot 分离配置文件的 N 种方式

江南一点雨

Java spring springboot

即时通讯技术文集(第6期):移动端弱网优化文章汇总 [共13篇]

JackJiang

网络编程 即时通讯IM

【Git实战】协同开发,如何紧急修复线上bug?

王中阳Go

git 高效工作 学习方法 git 学习 11月月更

一年前端面试打怪升级之路

loveX001

JavaScript

100万行Spring源代码,鬼知道面试都会问啥

博文视点Broadview

云图说|移动应用安全服务—App的体检中心,全面检测,安全上路!

华为云开发者联盟

华为云 移动应用安全 VSS

用户文章 | 原来Steam和Perforce有这种关系?!

龙智—DevSecOps解决方案

版本控制 版本管理工具 版本管理

分布式流处理组件-理论篇:Kafka与安装配置

谢先生F

架构 kafka 3.X 11月月更

React 中的重新渲染

阿里巴巴终端技术

前端 React

三次握手与四次挥的问题,怎么回答?

loveX001

JavaScript

云原生安全系列2:提升镜像安全的10条建议

HummerCloud

云原生 镜像安全 云原生安全

本地开发完成的 Fiori Elements 应用,部署到远端 ABAP 服务器上的详细步骤

汪子熙

web开发 abap Fiori SAP UI5 11月月更

再见 Fred Brooks

Journeyman

IT 新闻

火山引擎DataTester背后,抖音的名字原来是AB测试来的

字节跳动数据平台

大数据 AB testing实战

2022我的前端面试总结

loveX001

JavaScript

国内Quick BI为何可以入选魔力象限?

小偏执o

Basecamp发布JavaScript框架Stimulus 1.0_JavaScript_Dylan Schiemann_InfoQ精选文章