Svelte 最新中文文档翻译(5)—— 基础标记
前言
Svelte,一个非常“有趣”、用起来“很爽”的前端框架。从 Svelte 诞生之初,就备受开发者的喜爱,根据统计,从 2019 年到 2024 年,连续 6 年一直是开发者最感兴趣的前端框架 No.1:
Svelte 以其独特的编译时优化机制著称,具有轻量级、高性能、易上手等特性,非常适合构建轻量级 Web 项目,也是我做个人项目的首选技术栈。
目前 Svelte 基于 Svelte 5 发布了最新的官方文档,但却缺少对应的中文文档。为了帮助大家学习 Svelte,为爱发电翻译了官方文档。
我同时搭建了 Svelte 最新的中文文档站点:https://svelte.yayujs.com ,如果需要辅助学习,也可以入手我的小册《Svelte 开发指南》,语法篇、实战篇、原理篇三大篇章带你系统掌握 Svelte!
虽说是翻译,但个人并不喜欢严格遵守原文,为了保证中文阅读流畅,会删减部分语句,对难懂的部分也会另做补充解释,希望能给大家带来一个好的中文学习体验。
欢迎围观我的“朋友圈”、加入“低调务实优秀中国好青年”前端社群,分享技术,带你成长。
基础标记
Svelte 组件内的标记可以被理解为增强版的 HTML。
标签
小写标签,如 <div>,表示常规的 HTML 元素。大写标签或使用点符号的标签,如 <Widget> 或 <my.stuff>,表示一个组件。
<script>
import Widget from './Widget.svelte';
</script>
<div>
<Widget />
</div>
元素属性
默认情况下,属性的工作方式与其 HTML 对应项完全相同。
<div class="foo">
<button disabled>can't touch this</button>
</div>
与 HTML 一样,属性值可以不加引号。
<input type=checkbox />
属性值可以包含 JavaScript 表达式。
<a href="page/{p}">page {p}</a>
或者它们本身就可以是 JavaScript 表达式。
<button disabled={!clickable}>...</button>
如果布尔属性的值为真值,则会包含在元素中,如果为假值,则会被排除。
所有其他属性除非其值为空值(null 或 undefined),否则都会被包含。
<input required={false} placeholder="This input field is not required" />
<div title={null}>This div has no title attribute</div>
[!NOTE] 在单个表达式外加引号不会影响值的解析方式,但在 Svelte 6 中会导致值被强制转换为字符串:
<button disabled="{number !== 42}">...</button>
当属性名和值相同时(name={name}),可以简写为 {name}。
<button {disabled}>...</button>
<!-- 等同于
<button disabled={disabled}>...</button>
-->
组件属性
按照惯例,传递给组件的值被称为属性(properties)或props,而不是特性(attributes),后者是 DOM 的一个特征。
译者注:Property 和 Attributes 通常都翻译为“属性”,在做区分时,通常会将 Attributes 翻译为“特性”。Attributes 指的是直接在 HTML 元素上设置的值,通过提供元素的附加信息来指导其初始行为和状态。
与元素一样,name={name} 可以简写为 {name}。
<Widget foo={bar} answer={42} text="hello" />
展开属性允许一次性将多个特性或属性传递给元素或组件。
一个元素或组件可以有多个展开属性,并与常规属性交错使用。
<Widget {...things} />
事件
通过在元素上添加以 on 开头的属性,可以监听 DOM 事件。例如,要监听 click 事件,在按钮上添加 onclick 属性:
<button onclick={() => console.log('clicked')}>click me</button>
事件属性区分大小写。onclick 监听 click 事件,onClick 监听 Click 事件,这是不同的。这确保你可以监听包含大写字符的自定义事件。
因为事件只是属性,所以适用与属性相同的规则:
- 你可以使用简写形式:
<button {onclick}>click me</button> - 你可以展开它们:
<button {...thisSpreadContainsEventAttributes}>click me</button>
在时序上,事件属性总是在绑定事件之后触发(例如,oninput 总是在 bind:value 更新后触发)。在底层,一些事件处理程序是直接通过 addEventListener 附加的,而其他的则是委托的。
当使用 ontouchstart 和 ontouchmove 事件属性时,处理程序是passive可以获得更好的性能。这极大地提高了响应性,因为浏览器可以立即滚动文档,而不是等待查看事件处理程序是否调用 event.preventDefault()。
在极少数情况下,如果你需要阻止这些事件的默认行为,你应该使用 on(例如在 action 内部)。
事件委托
为了减少内存占用并提高性能,Svelte 使用了一种称为事件委托的技术。这意味着对于某些事件(见下面的列表),在应用程序根部的单个事件监听器负责运行事件路径上的所有处理程序。
需要注意以下几个陷阱:
- 当你手动触发一个带有委托监听器的事件时,确保设置
{ bubbles: true }选项,否则它将无法到达应用程序根部 - 当直接使用
addEventListener时,避免调用stopPropagation,否则事件将无法到达应用程序根部,处理程序将不会被调用。同样,在应用程序根部手动添加的处理程序将在 DOM 深处声明式添加的处理程序(例如用onclick={...})之前运行,无论是在捕获还是冒泡阶段。出于这些原因,最好使用从svelte/events导入的on函数,而不是addEventListener,因为它将确保顺序得到保持,并且正确处理stopPropagation。
以下事件处理程序是委托的:
beforeinputclickchangedblclickcontextmenufocusinfocusoutinputkeydownkeyupmousedownmousemovemouseoutmouseovermouseuppointerdownpointermovepointeroutpointeroverpointeruptouchendtouchmovetouchstart
文本表达式
可以通过将 JavaScript 表达式用大括号括起来将其作为文本包含。
{expression}
可以通过使用它们的 HTML 实体字符串在 Svelte 模板中包含大括号:{、{ 或 { 表示 {,}、} 或 } 表示 }。
如果你使用正则表达式(RegExp)字面量表示法,你需要用括号将其括起来。
<h1>Hello {name}!</h1>
<p>{a} + {b} = {a + b}.</p>
<div>{(/^[A-Za-z ]+$/).test(value) ? x : y}</div>
表达式将被字符串化并转义以防止代码注入。如果你想渲染 HTML,请使用 {@html} 标签。
{@html potentiallyUnsafeHtmlString}
[!NOTE] 确保你要么对传入的字符串进行转义,要么只使用你控制下的值来填充它,以防止 XSS 攻击
注释
你可以在组件内使用 HTML 注释。
<!-- this is a comment! --><h1>Hello world</h1>
以 svelte-ignore 开头的注释会禁用下一个标记块的警告。通常,这些是可访问性警告;确保你有充分的理由禁用它们。
<!-- svelte-ignore a11y-autofocus -->
<input bind:value={name} autofocus />
你可以添加一个以 @component 开头的特殊注释,当在其他文件中悬停在组件名称上时会显示该注释。
<!--
@component
- You can use markdown here.
- You can also use code blocks here.
- Usage:
```html
<Main name="Arethra">
```
-->
<script>
let { name } = $props();
</script>
<main>
<h1>
Hello, {name}
</h1>
</main>
Svelte 中文文档
本篇已收录在掘金专栏 《Svelte 中文文档》,该系列预计 40 篇。
系统学习 Svelte,欢迎入手小册《Svelte 开发指南》。语法篇、实战篇、原理篇三大篇章带你系统掌握 Svelte!
此外我还写过 JavaScript 系列、TypeScript 系列、React 系列、Next.js 系列、冴羽答读者问等 14 个系列文章, 全系列文章目录:https://github.com/mqyqingfeng/Blog
通过文字建立交流本身就是一种缘分,欢迎围观我的“朋友圈”、加入“低调务实优秀中国好青年”前端社群,分享技术,带你成长。
Svelte 最新中文文档翻译(5)—— 基础标记的更多相关文章
- SQLAlchemy 中文文档翻译计划
SQLAlchemy 中文文档翻译计划已启动. Python 文档协作翻译小组人手紧缺,有兴趣的朋友可以加入我们,完全公益性质.交流群:467338606. 希望大家能够勇敢地去翻译和改进翻译.虽然我 ...
- Laravel 5.3 中文文档翻译完成
经过一个多月的紧张翻译和校对,翻译完成.以下是参与人员: Laravel 5.3 中文文档翻译完成 稿源:七星互联www . qixoo.com 文档地址在此:https://laravel-chin ...
- 參与 Spring 4 中文文档翻译
參与 Spring 4 中文文档翻译 我们从2014年12月開始翻译Spring 4的框架文档.尽管至今已有一年,可是进度非常慢. 当中一部分原因是由于Spring 文档有1000多页,并且翻译的时候 ...
- Orchard core 中文文档翻译系列
本系列翻译顺序完全参照 官方顺序 原文地址:https://orchardcore.readthedocs.io/en/latest/ Orchard Core 中文文档翻译(一)关于Orchard ...
- Unity3d 游戏中集成Firebase 统计和Admob广告最新中文教程
之前写过俩相关的教程,最近发现插件官方更新了不少内容,所以也更新一篇Firebase Admob Unity3d插件的教程,希望能帮到大家. Firebase Admob Unity3d插件是一个Un ...
- 2019年最新50道java基础部分面试题
[软帝学院]1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语法,集合的语法,io 的语法,虚拟机方面的语法. 1.一个".j ...
- Hugo 博客中文指南(基础教程)
1. 安装 Hugo 从 Hugo 项目主页下载 Releases 文件,解压 hugo.exe 文件到 C:\Windows\System32 目录下. 2. 创建站点 hugo new site ...
- Spring MVC中文文档翻译发布
前后经过九个月,我翻译的Spring MVC官方4.2.4版本中文文档可以发布第一个较为完整的版本了.译文上尽量做到准确并且符合中文习惯,让人能读懂,能理解.现全文发布如下,也希望它能够给出其价值,并 ...
- vscode 最新中文设置
切换中文 首先看商店里有没有chinese language那个中文插件. 在ctrl + shift +p 搜索configure language,然后配置locale如下即可配置中文.
- Orchard Core 中文文档翻译(一)关于Orchard Core
原文连接:https://www.cnblogs.com/Qbit/p/9746363.html 转载请注明出处 翻译说明:本系列为直译,按照官方的计划现在这个版本(2018年10月5日)已经接近最终 ...
随机推荐
- 多校A层冲刺NOIP2024模拟赛08 排列
多校A层冲刺NOIP2024模拟赛08 排列 一种连续段 dp 的解法. 题面 小 Y 最近在研究组合数学,他学会了如何枚举排列. 小 Z 最近在研究数论,他学会了求最大公约数. 于是小 Y 和小 Z ...
- 二、FreeRTOS学习笔记-移植
FreeRTOS移植 首先准备一个基础工程,stm32标准库或者HAL库,本实验使用HAL库版本的内存管理实验进行移植 移植步骤: 1 第一步:添加FreeRTOS源码(添加FreeRTOS源码的目的 ...
- python多版本管理软件pyenv
我们在平时的项目开发或者学习中,有可能使用不同的Python版本,大家都知道Python的版本非常多,如果我们把需要的不同版本的Python都下载到服务器上,管理起来会非常困难,多版本并存又容易互相干 ...
- phpstorm之代码质量工具
在进行php开发的时候, 经常由于编码上的不规范导致了隐藏的bug,这里介绍代码质量工具 PHP CodeSniffer: phpcs [安装] composer require squizla ...
- Nuxt.js 应用中的 render:response 事件钩子
title: Nuxt.js 应用中的 render:response 事件钩子 date: 2024/11/29 updated: 2024/11/29 author: cmdragon excer ...
- canvas(二)直线样式和虚线
1.设置直线线帽的样式 相关语法:ctx.lineCap,通过赋值形式来设置直线线帽的样式,他有以下3个值: 值 说明 butt 默认 round 圆形线帽 square 正方形线帽 <scri ...
- MySql 9 in Docker 主从切换
继上一篇<MySql 9 in Docker 利用克隆插件搭建主从>我们说了主从复制后, 那么我们接下来说说如何手动的进行主从切换. 动手~ 1. 原主库设置 切断应用对主库的访问 主库设 ...
- ChatGPT在功能测试用例生成方面的优势
功能测试是软件测试的非常重要的分类,所有软件系统都要保证功能的正确性,而测试用例则是功能测试的重中之重.测试用例的编写是测试人员必须认真面对的一件耗时费力.枯燥乏味的工作.如何才能快速高效地编写测试用 ...
- Git clone报错“Connection was reset, errno 10054”
前情 最近在使用一个UI库的时候,发现其中一个BUG,于是想尝试提一个PR. 坑位 我平时习惯用https的方式拉取代码,发现在clone代码的时候一直失败,错误提示:OpenSSL SSL_read ...
- 前端每日一知之让Chrome支持小于12px的文字
脑图在线链接 本文内容依据[js每日一题]公众号精彩文章总结而来