JavaScript Library – Svelte
前言
上一回我介绍了 Alpine.js。作为我开发企业网站 draft 版本的 render engine。
用了一阵子后,我觉得它真的非常不好用。所以打算换一个。
前端有好几个 framework / library / compiler 都可以用来做 MVVM render engine。比如 Angular、React、Vue、Lit、Solid、Qwik、Svelte。
Angular 太重
React、Solid、Qwik 我不爱 JSX
Vue 半吊子
Lit 我不能接受 html`` 语法
所以最后选了 Svelte。
安装
它有 2 个用法,第一个是搭配 SvelteKit,类似于 Angular CLI,官方出的脚手架。
另一个方法是搭配 Vite,我是要轻巧的,自然是不想引入多一个 SvelteKit 概念,用 Vite 足也。
Vite 我之前介绍过了,没用过的人可以先看这篇。
更新:17-11-2023,新版本只需要一行 command 就可以创建给予 vite 的 svelte 了。

下面是以前的安装方式,留作纪念。
yarn create vite
然后填写 project name 选择 Svelte 模板和 TypeScript

进入 folder 安装 node_modules 就可以了
cd play-svelte
yarn install
yarn dev --open
效果

vite config with svelte
我们看看是怎样 config svelte to vite 的
首先 vite.config.ts 多了一个 svelte plugin

多了一个 svelte.config.js 里面是 vite plugin

这样一来一往,两家就连上了。
还有一个重要的是 tsconfig.json

大致上是这样。
Svelte 的基本使用概念
我的目的是用它来替代 Razor。所以我只关心一些小功能而已。
index.html 作为 page 的入口

导入 main.ts 这个和一般的 Vite 使用是一样的。
然后 main.ts 长这样

关键就在那个 App.svelte。
.svelte 类似于 Blazor 的 .razor file。它是 Script (JS / TS) + HTML + Style (CSS / Scss) 的合体。

一个 .svelte file 等于一个组件。它也有 isolated css 的概念哦,但不关我的事,我用不上。
Svelte 的基本语法
binding text
<script lang="ts">
const name = 'Derrick';
</script> <main>
<h1>{name}</h1>
</main>
非常简单直接
binding html raw text
<script lang="ts">
const rawHtml = '<h1>Hello World</h1>';
</script> <main>
{ @html rawHtml }
</main>
click event and change binded text
<script lang="ts">
let name = 'Derrick';
</script> <main>
<h1>{name}</h1>
<button on:click={() => name = 'new name'}>change name</button>
</main>
效果

简单到爆,不需要像 Solid、Angular 那样去搞什么 Signal / Reactive 做追踪,逼迫开发者写出恶心代码。直接了当就是 Svelte 的风格。
当然这种黑箱有时候也很恐怖。类似重新定义 HTML、CSS、JS 了,但是这种事后端经常干,见怪不怪。
binding property / attribute
<h1 class="{ 'abc ' + (true ? 'xyz' : 'kknd') }">Hello World</h1>
<input type="text" required={true}>
<h1 class:active={true} >Hello World</h1>
直接写 JS 拼接 class 也是可以的。简单直接
if else
{#if Math.random() > 0.1}
<h1>Hello World</h1>
{:else if Math.random() > 0.4}
<p>too cold!</p>
{:else}
<h1>false value</h1>
{/if}
Angular 也正在考虑用上面这个写法。比起 Razor 确实有点丑。
for loop
{#each values as value, index}
<h1 class="item">{value}</h1>
{/each}
component
counter.svelte
一个 .svelte 代表一个组件
<script lang="ts">
export let startNumber;
let count = startNumber;
</script> <main>
<h1>{count}</h1>
<button on:click={() => count++}>increase</button>
</main> <style>
h1 {
color: red;
}
</style>
script 里面的 export let startNumber 组件的 property,外部通过修改这个影响组件内部。类似 Angular 的 @Input
app.svelte
<script lang="ts">
import Counter from './Counter.svelte';
let name = 'Derrick';
</script> <main>
<h1>{name}</h1>
<button on:click={() => name = 'new name'}>change name</button>
<Counter startNumber="5" />
</main>
使用组件的方式是 import 组件,然后写入 HTML。
component slot
外面传进去
<Counter startNumber="5">
<div class="header" slot="header">header</div>
<div slot="footer">footer</div>
</Counter>
里面接收
<main>
<slot name="header">
No header was provided
</slot> <h1>{count}</h1>
<button on:click={() => count++}>increase</button> <slot name="footer"></slot>
</main>
简单直接。题外话: <slot> 在 HTML 规范里不是 self-closing tag 哦,但 Svelte 依然可以正确解释的。
component slot 和 fragment slot
<HeaderComponent slot="header" />
组件和 element 一样可以直接写 slot property。
fragment slot 长这样,有点类似 Angular 的 ng-container
<svelte:fragment slot="footer">
<p>All rights reserved.</p>
<p>Copyright (c) 2019 Svelte Industries</p>
</svelte:fragment>
component pass multiple properties
<MyComponent {...props} />
Svelte 其它知识点
获取 DOM 的时机

new Component 后,DOM 就渲染好了。
总结
目前我就用到这些而已。感觉无论如何都比 Alpine.js 合适。我喜欢他的简单直接,希望他越来越火,有朝一日我可以用它于 production 场景。
JavaScript Library – Svelte的更多相关文章
- A javascript library providing cross-browser, cross-site messaging/method invocation. http://easyxdm.net
easyXDM - easy Cross-Domain Messaging easyXDM is a Javascript library that enables you as a develope ...
- Dynamices CRM JS 类库 神器 XrmServiceToolkit - A Microsoft Dynamics CRM 2011 & CRM 2013 JavaScript Library
XrmServiceToolkit - A Microsoft Dynamics CRM 2011 & CRM 2013 JavaScript Library http://xrmservic ...
- Raphaël—JavaScript Library
Raphaël-JavaScript Library What is it? Raphaël is a small JavaScript library that should simplify yo ...
- a Javascript library for training Deep Learning models
w强化算法和数学,来迎接机器学习.神经网络. http://cs.stanford.edu/people/karpathy/convnetjs/ ConvNetJS is a Javascript l ...
- JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布
JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布 研究了一年多的js,也差不多写一个自己的js库了.我写这个不算框架,只是一个小型的js工具 ...
- jQuery JavaScript Library v3.2.1
/*! * jQuery JavaScript Library v3.2.1 * https://jquery.com/ * * Includes Sizzle.js * https://sizzle ...
- A JavaScript library for reading EXIF meta data from image files.
exif-js/exif-js: JavaScript library for reading EXIF image metadata https://github.com/exif-js/exif- ...
- javascript library
<!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...
- 转:Build Your First JavaScript Library
http://net.tutsplus.com/tutorials/javascript-ajax/build-your-first-javascript-library/ Step 1: Creat ...
- [React] 01 - Intro: javaScript library for building user interfaces
教学视频: http://www.php.cn/code/8217.html React 教程: http://www.runoob.com/react/react-tutorial.html 本篇是 ...
随机推荐
- PositiveSmallIntegerField、SmallIntegerField和IntegerField
当您在Django中定义模型时,有几种不同的整数字段类型可供选择,包括PositiveSmallIntegerField.SmallIntegerField和IntegerField.以下是这三种整数 ...
- [oeasy]python001_先跑起来_python_三大系统选择_windows_mac_linux
先跑起来 Python 什么是 Python? Python [ˈpaɪθɑ:n] 是 一门 适合初学者 的编程语言 添加图片注释,不超过 140 字(可选) 类库 众多 几行代码 就 ...
- 2024 暑假友谊赛-热身2 (7.12)zhaosang
E-E https://vjudge.net/problem/AtCoder-diverta2019_b 给你 a, b, c ,n就是问你有多少(ia+jb+k*c)等于n的答案i,j,k任意几个都 ...
- C语言数据类型转换(自动类型转换+强制类型转换)
自动类型转换 1) 将一种类型的数据赋值给另外一种类型的变量时就会发生自动类型转换,例如: float f = 100; int n = f; f 是 float 类型的数据,需要先转换为 int 类 ...
- innodb存储引擎了解
mysql常用的存储引擎分为innodb和myisam 其中innodb具有支持事务,执行行级锁,支持MVCC,外键,自动增长列,崩溃恢复等特性.并且mysql在5.5.5之后是数据的默认存储引擎 文 ...
- Cloudflare教程:如何注册账户、购买域名、开启免费CDN服务?
Cloudflare介绍 什么是Cloudflare Cloudflare是一家总部位于旧金山的美国跨国科技企业,以向客户提供基于反向代理的内容分发网络(CDN)及分布式域名解析服务为主要业务. 目前 ...
- 题解 WD与数列
P5161 WD与数列 可以想到原条件是一个差分形式,所以我们对原数组差分.然后发现答案其实就是 \(\sum_{i<j} \min(lcp(i+1,j+1)+1,j-i)\). 这个东西先跑 ...
- 自写Json转换工具
前面写了简单的API测试工具ApiTools,返回的json有时需要做很多转换,于是开发了这个工具. 功能包括 1.json字符串转为表格,可以直观的展示,也可以复制,并支持转换后的表格点击列头进行排 ...
- 实现一个终端文本编辑器来学习golang语言
欢迎!这个系列的博文会带你使用golang语言来编写一个你自己的文本编辑器. 首先想说说写这个系列文章的动机. 其实作为校招生加入某头部互联网大厂一转眼已经快4年了.可以说该大厂算是比较早的用gola ...
- 中国特供版4090D已经开始发售
由于美国政府的限制,NVIDIA公司等美国公司不允许向中国出口4090显卡,但是为了绕过美国政府的限制NVIDIA公司推出了中国特供版的4090D显卡. 4090d显卡和4090显卡区别大吗?可以说其 ...