IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Svelte3.x自定义Navbar+Tabbar组件 -> 正文阅读

[JavaScript知识库]Svelte3.x自定义Navbar+Tabbar组件

Svelte 是构建 Web 应用程序的一种新框架。Svelte 是一个编译器,它将声明性组件转换成高效的 JavaScript 代码,并快速响应细粒度地更新 DOM。

最近一直在学习前端新框架Svelte。号称比vue还快,无虚拟dom操作。
今天就给大家分享一些svelte自定义组件的相关知识。

在这里插入图片描述
在lib公共目录下新建headerbar和tabbar组件。
在这里插入图片描述
在需要使用组件的页面或者公共模板__layout.svelte中引入组件。

import HeaderBar from '$lib/HeaderBar.svelte';
import TabBar from '$lib/TabBar.svelte';

svelte自定义导航条headerbar组件

在vue中通过props来定义组件属性,而在svelte则是通过export导出自定义属性。

<!-- //自定义HeaderBar组件 -->
<script>
    // 是否显示回退按钮
    export let back = true
    // 标题
    export let title = ''
    // 颜色
    export let color = '#fff'
    // 背景色
    export let bgcolor = '#22d59c'
    // 是否居中标题
    export let center = false
    // 是否固定
    export let fixed = false
    // 是否镂空透明
    export let transparent = false
    // 层级
    export let zIndex = 2021

    function goBack() {
        console.log('go back')
        history.go(-1)
        // history.back(-1)
    }
</script>
<div class="header-bar" class:transparent class:fixed={transparent||fixed}>
    <div class="header-bar__wrap flexbox flex-alignc" style:color style:background={bgcolor} style:z-index={zIndex}>
        <!-- //返回 -->
        {#if back && back != 'false'}
            <div class="action hdbar-action__left" on:click={goBack}>
                <slot name="backIco" /><slot name="backText" />
            </div>
        {/if}

        <!-- //标题 -->
        <div class="hdbar-title" class:center>
            {#if $$slots.title}
                <slot name="title" />
            {:else}
                {@html title}
            {/if}
        </div>

        <!-- //搜索框 -->
        <div class="action hdbar-action__search">
            <slot name="search" />
        </div>

        <!-- //右侧 -->
        <div class="action hdbar-action__right">
            <slot name="right" />
        </div>
    </div>
</div>

在这里插入图片描述
支持 自定义背景(渐变色)、文字颜色、标题居中、搜索框、沉浸式悬浮、是否固定及层叠等功能。
另外还支持 自定义插槽 丰富组件功能,实现一些地址选择、圆点提示、图片等功能。

<HeaderBar back="false" bgcolor="linear-gradient(to right, #36f4da, #f889ff)" color="#fff">
    <svelte:fragment slot="title">上海 <i class="iconfont icon-arrD"></i></svelte:fragment>
    <svelte:fragment slot="search">
        <div class="seach-box flex-c flex1">
            <input class="ipt flex1" placeholder="Search..." />
        </div>
    </svelte:fragment>
    <svelte:fragment slot="right">
        <div class="btn"><i class="iconfont icon-weizhi"></i></div>
        <div class="btn"><img src="img/logo.png" height="12" alt="" /></div>
    </svelte:fragment>
</HeaderBar>

svelte自定义tabbar组件

在这里插入图片描述

/**
 * @Desc     Svelte自定义Tabbar组件
 * @Time     andy by 2022/3/12
 * @About    Q:282310962  wx:xy190310
 */
<script>
    // tab默认索引
    export let current = 0
    // 文字颜色
    export let color = '#999'
    // 背景色
    export let bgcolor = '#fff'
    // 激活颜色
    export let activeColor = '#ff3e00'
    // 是否固定
    export let fixed = false
    // tab选项
    export let tabs = [
        {
            path: '/',
            icon: 'icon-face',
            title: '消息',
            badge: 18,
        },
        {
            path: '/contact',
            // icon: 'icon-choose',
            img: 'https://img.yzcdn.cn/vant/user-inactive.png',
            activeImg: 'https://img.yzcdn.cn/vant/user-active.png',
            title: '联系人',
        },
        {
            path: '/me',
            icon: 'icon-female',
            title: '我',
            dot: true,
        }
    ]

    import { page } from '$app/stores'
    import { goto } from '$app/navigation'
    import { onMount, createEventDispatcher } from 'svelte'
    const dispatch = createEventDispatcher()

    $: currentTabIndex = current

    onMount(() => {
        console.log('路由:', $page)
        console.log('路由地址:', $page.url)
        const curPath = $page.url.pathname
        tabs.map((item, index) => {
            if(item.path == curPath) {
                currentTabIndex = index
            }
        })
    })

    function changeTabs(index, item) {
        currentTabIndex = index
        dispatch('click', index)
        if(item.path) {
            goto(item.path)
        }
    }
</script>
<div class="tab-bar" class:fixed>
    <div class="tab-bar__wrap flexbox flex-alignc" style="background: {bgcolor}">
        {#each tabs as item,i}
            <div class="navigator" class:on={currentTabIndex==i} on:click={changeTabs(i, item)}>
                <div class="ico" class:dock={item.dock}>
                    {#if item.dock}<i class="dock-bg" style:background={item.dockBg ? item.dockBg : activeColor}></i>{/if}
                    {#if item.icon}<i class={'iconfont '+item.icon} style:color={currentTabIndex == i && !item.dock ? activeColor : color} style:font-size={item.iconSize}></i>{/if}
                    {#if item.img}<img class="iconimg" src={currentTabIndex == i && !item.dock ? item.activeImg : item.img} style:font-size={item.iconSize} />{/if}
                    {#if item.badge}<em class="vui__badge">{@html item.badge}</em>{/if}
                    {#if item.dot}<em class="vui__badge-dot"></em>{/if}
                </div>
                <div class="txt" style:color={currentTabIndex == i ? activeColor : color}>{@html item.title}</div>
            </div>
        {/each}
    </div>
</div>

支持自定义背景(渐变背景)、文字颜色|选中颜色、是否固定、中间按钮dock凸起等功能。

<script>
    // ...

    // 点击tabbar选项
    function handleTabbar(e) {
        console.log('tabbar索引值:' + e.detail)
    }
</script>

<TabBar bgcolor="#ffc107" color="#fff" activeColor="#fb4e30" on:click={handleTabbar}
    tabs={
        [
            {
                icon: 'icon-face',
                title: 'Face',
                dot: true,
                iconSize: '24px'
            },
            {
                img: 'https://gw.alicdn.com/tfs/TB1CoEwVrvpK1RjSZFqXXcXUVXa-185-144.png',
                title: '咸鱼',
                dock: true,
                dockBg: '#f00',
                iconSize: '30px',
            },
            {
                path: '/me',
                icon: 'icon-female',
                title: '我',
            },
        ]
    }
/>

注意

vue通过this.$emit来向父组件传递事件。而在svelte中则是通过createEventDispatcher来处理事件传递。

import { createEventDispatcher } from 'svelte'
const dispatch = createEventDispatcher()
dispatch('click', ...)

svelte获取页面路由地址

import { page } from '$app/stores'
// $page.url.pathname  获取路由地址

svelte函数跳转页面

import { goto } from '$app/navigation'
// goto(url)  goto('/news')  跳转页面

好了,svelte自定义组件就分享到这里。后面还会分享一个svelte自定义弹窗组件。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 21:41:13  更:2022-03-13 21:43:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:07:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码