【Svelte】-(6)绑定|input 输入框 / group 复选框绑定 / textarea 输入框 / select 绑定 / contenteditable 属性绑定



input 输入框

一般来说,数据流是自上而下的,就像父组件可以在子组件上设置 props,组件可以在元素上设置属性,但反过来不行。但是我们以 <input> 这个标签为例,我们可以添加一个事件处理,来获取 event.target.value,但这就有点没必要了吧。

所以,Svelte为了方便我们,我们可以直接使用 bind:value 指令,不止 <input> 标签,很多标签的属性我们可以直接添加 bind: 来动态获取或者管理。

下面我们来看一个案例

<script>
  let nikeName = '我想养只猫'
  let age = 99
</script>

<div>
  <p>
    设置您的用户名:
    <input bind:value={nikeName}>
  </p>
  <p>
    设置您的年龄:
    <input bind:value={age} type=number min=18>
    <input bind:value={age} type=range min=18>
  </p>
</div>

<div style="opacity: .6">
  <p>
    您的用户名是:{nikeName}
  </p>
  <p>
    您的年龄是:{age}
  </p>
</div>

在这里插入图片描述

有一个好玩的是,设置年龄之后绑定了 age 的标签,数据也会同步

在这里插入图片描述



group 复选框绑定

我们还可以绑定 checked

<script>
  let isFollower = true
</script>

<label>
  <input type=checkbox bind:checked={isFollower}>
  关注,CSDN 我想养只猫
</label>

<p style="margin-top: 10px">
  {isFollower}
</p>

在这里插入图片描述

如果有多个与同一值相关的输入,则可以用 bind:groupvalue 属性一起使用。

以下是一个完整示例:

<script>
  let radioData = 0
  let checkboxArray = [0]
</script>

{#each [...Array(3).keys()] as i}
  <label>
    <input type=radio bind:group={radioData} value={i}>
    {i}
  </label>
{/each}

<p>
  选择的是: {radioData}
</p>

<hr />

{#each [...Array(5).keys()] as i}
  <label>
    <input type=checkbox value={i} bind:group={checkboxArray}>
    {i}
  </label>
{/each}

<p>
  选择的是: {checkboxArray}
</p>

在这里插入图片描述

如果有认真,你就会发现 checkboxgroup 类型是数组。



textarea 输入框

<input > 是相通的,之所以单独列出来,就是为了给大家看一个示例,为了帮助你区分 <input><textarea> 的应用场景。

<script>
  let name = ''
  let info = ''
</script>

用户名:<input bind:value={name}>
<p>
  个人简介:
</p>
<p>
  <textarea style="height: 100px;width: 300px" bind:value={info}></textarea>
</p>

<div style="opacity: .6;margin-top: 50px">
  用户名:{name}
  <p>
    个人简介:
  </p>
  <p>
    {@html info}
  </p>
</div>

在实际生产中应当防止xss攻击,此处仅示例,请勿直接将用户输入的内容直接进行展示,应当进行适当的过滤和处理,保证web安全。

在这里插入图片描述



select 绑定

我们可以使用 bind:value 绑定 <select> 标签。

如果我们不设置 value 的初始值,会自动将列表中的第一个设置为默认值。所以建议设置一个初始值(按照你的需求来)

下面我们来看一个案例

<script>
  let menu = [...Array(5).keys()]
  let value = 3
</script>

<select bind:value={value}>
  {#each menu as i}
    <option value={i}>
      选项 {i}
    </option>
  {/each}
</select>

<p>{menu} 中选择了 <b>{value}</b>
</p>

在这里插入图片描述
<select> 标签可以有一个 multiple 属性,这种情况下绑定的 value 类型需要设置为数组类型。

<script>
  let menu = [...Array(5).keys()]
  let value = [0,1,2]
</script>

<select bind:value={value} multiple>
  {#each menu as i}
    <option value={i}>
      选项 {i}
    </option>
  {/each}
</select>

<p>{menu} 中选择了 <b>{value}</b>
</p>

在这里插入图片描述



contenteditable 属性绑定

设置 contenteditable 属性之后,支持添加 textContentinnerHTML 属性绑定内容 (标签内容)

<script>
  let html, text
</script>

<div
  contenteditable="true"
  bind:innerHTML={html}
  bind:textContent={text}
>
  <p>hello</p>
</div>

<p>
  <b>bind:innerHTML内容:</b> {html}
</p>
<p>
  <b>bind:textContent内容:</b> {text}
</p>

在这里插入图片描述

在这里插入图片描述



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Svelte-routing 是一个基于 Svelte 的轻量级路由库,它提供了基本的路由功能,包括路由参数、嵌套路由、重向等特性。使用 Svelte-routing 非常简单,你可以按照以下步骤进行配置: 1. 安装 Svelte-routing 你可以使用 npm 或 yarn 安装 Svelte-routing: ``` npm install --save svelte-routing ``` 或 ``` yarn add svelte-routing ``` 2. 导入 Router 和 Route 组件 在 Svelte 应用中,你需要使用 Router 和 Route 组件来义路由规则。你可以在需要使用路由的组件中导入这两个组件: ```js import { Router, Route } from 'svelte-routing'; ``` 3. 义路由规则 使用 Router 和 Route 组件,你可以义应用的路由规则。例如,你可以在 App.svelte 文件中义两个路由规则,分别对应着应用的 / 和 /about 路径: ```html <Router> <Route path="/" component={Home} /> <Route path="/about" component={About} /> </Router> ``` 在这个例子中,Home 和 About 分别是两个 Svelte 组件,它们会在对应的路由被匹配时被渲染。 4. 使用路由参数 Svelte-routing 支持路由参数,你可以在路由规则中使用冒号(:)来义动态参数。例如,你可以义一个 /user/:id 路径,其中 :id 表示一个动态参数。当用户访问 /user/123 时,Svelte-routing 会自动将参数传递给对应的组件。你可以在组件中使用 $routeParams.id 来获取该参数。例如: ```html <!-- 义路由规则 --> <Route path="/user/:id" component={User} /> <!-- User 组件中获取参数 --> <script> export let $routeParams; console.log($routeParams.id); </script> ``` 5. 使用重Svelte-routing 还支持重向功能,你可以在路由规则中使用 redirect 属性来实现重向。例如,你可以将 /about 路径重向到 /about-us 路径: ```html <Route path="/about" redirect="/about-us" /> ``` 以上就是使用 Svelte-routing 实现基本路由功能的步骤。Svelte-routing 还支持嵌套路由、路由守卫等高级功能,你可以查阅官方文档来学习更多内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我想养只猫 •͓͡•ʔ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值