Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

虚幻大学 xuhss 198℃ 0评论

Python微信订餐小程序课程视频

https://edu.csdn.net/course/detail/36074

Python实战量化交易理财系统

https://edu.csdn.net/course/detail/35475
基于svelte3.x+svelteKit构建仿微信App聊天应用svelte-chatroom

svelte-chatroom 基于svelte.js+svelteKit+mescroll.js+svelte-popup等技术搭建开发的仿微信app界面聊天项目。支持发送图文消息/gif动图、图片/视频预览、下拉刷新、红包及朋友圈等功能。

84dec46329f4d7c48c4f49e3e98ee703 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

一、技术框架

  • 编码器:VScode
  • 框架技术:svelte^3.46.0+svelteKit
  • 下拉组件:mescroll.js^1.4.2
  • 样式处理:sass+svelte-preprocess
  • 弹窗组件:svelte-popup
  • 数据模拟:mockjs^1.1.0

233fe66eef1ffcddfb00ff08a6edb900 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

svelte.js 一款号称比vue.js还快的前端新框架。体积小、运行速度快、无虚拟DOM、快速的响应能力。

https://svelte.dev/

d013db4ed57942c54340e9dd3eddec5a - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

04959740abaf6a878e66e814812e489c - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

a17c121c625eb37ceac1125fffeef945 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

cd92d5c6c1269963337b3b8ff9a34692 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

bd786296b98fc6a8a2e7916f7280891b - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

281122f40b644a17196897396ded39f9 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

9155d614358827ad40955c60f724fb88 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

4e956d85ea37fe8b97a7c2d40211660d - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

a08e73d4358b99a58e705190ab53fadf - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

99f7aabff1cde1fdf0b31fd1c921ddab - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

619c98feacb684f2b5d7a99021f40c9f - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

20de7830c67d60b226c84d564bd7ae51 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

04515eb23df2c2c2fe33c8072d5d7a90 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

709f8b9c43ee2388feff1cecfa97cb0d - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

2cd80fd06159cbc12098fa0d44d6efe6 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

be540968f5413bf4424ae244aa6a1a12 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

deb5873c670d82add2783700c2a25e01 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

cc65e2c058d57e681a736d959c34640f - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

9a03e2f201ecf5501913d254a441618c - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

ada9bb38b716372cf92bf736be096d1d - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

二、项目结构目录

使用svelte+svelteKit构建的项目,目录结构如下。

fd0e7834b974abaf02727d72093f7da3 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

◆ Svelte.js自定义导航栏Navbar+菜单栏Tabbar

项目中顶部导航条及底部菜单栏均是基于svelte定制开发的自定义组件。

78bfd096314786d09f1168120d847e66 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

d054a14156056f25bc4c75da0a004366 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

8a291296139fb80be745f7d0d6ee74dd - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

至于如何使用svelte开发自定义组件,就不作过多的介绍,大家感兴趣的话,可以去看看这篇分享文章。

https://blog.csdn.net/xiaoyan2017/p/15996146.html

◆ Svelte.js自定义手机端弹窗组件

svelte-popup 一款基于Svelte3.x开发自定义多功能svPopup弹出框组件,支持超过20+参数自由配置、组件式+函数式混合调用方式。

a3a6276fa064f98f6c2e342bd3d11118 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

具体的实现步骤这里不作详细介绍,大家可以去看看下面这篇分享文章。

https://blog.csdn.net/xiaoyan2017/p/16015575.html

◆ svelte.config.js配置文件

如何在svelte.js项目中使用sass/less编写样式?可以安装 sass 及 svelte-preprocess 依赖。

9f0116dc30eb14779ce75f499175a018 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

/**
 * svelte.config.js基础配置文件
 */

import adapter from '@sveltejs/adapter-auto'
import path from 'path'
import SvelteProcess from 'svelte-preprocess'

/** @type {import('@sveltejs/kit').Config} */
const config = {
 kit: {
 adapter: adapter(),
 vite: {
 resolve: {
 alias: {
 '@': path.resolve('./src'),
 '@assets': path.resolve('./src/assets'),
 '@utils': path.resolve('./src/utils')
 }
 }
 }
 },
 // allow you to use Svelte with tools like TypeScript, PostCSS, SCSS, and Less.
 preprocess: SvelteProcess()
};

export default config

◆ SvelteKit公共模板及错误页

使用svelteKit构建的项目,公共模板__layout.svelte及错误页__error.svelte配置如下。

<span style="color: rgba(0, 0, 0, 1)">
 import { onMount } from </span>'svelte'<span style="color: rgba(0, 0, 0, 1)">
 import { page } from </span>'$app/stores'<span style="color: rgba(0, 0, 0, 1)">
 import { goto } from </span>'$app/navigation'<span style="color: rgba(0, 0, 0, 1)">
 import { userinfo } from </span>'@/store/index.js'<span style="color: rgba(0, 0, 0, 1)">

 let whiteRoute </span>= ['/auth/login', '/auth/register'<span style="color: rgba(0, 0, 0, 1)">]

 onMount(() </span>=><span style="color: rgba(0, 0, 0, 1)"> {
 </span><span style="color: rgba(0, 0, 255, 1)">if</span>(!<span style="color: rgba(0, 0, 0, 1)">$userinfo) {
 goto(</span>'/auth/login'<span style="color: rgba(0, 0, 0, 1)">)
 }</span><span style="color: rgba(0, 0, 255, 1)">else</span><span style="color: rgba(0, 0, 0, 1)"> {
 </span><span style="color: rgba(0, 0, 255, 1)">if</span><span style="color: rgba(0, 0, 0, 1)">(whiteRoute.includes($page.url.pathname)) {
 goto(</span>'/'<span style="color: rgba(0, 0, 0, 1)">)
 }</span><span style="color: rgba(0, 0, 255, 1)">else</span><span style="color: rgba(0, 0, 0, 1)"> {
 goto($page.url.pathname)
 }
 }
 })
</span>

<span style="color: rgba(0, 0, 0, 1)">
 @import </span>'@/app.scss'<span style="color: rgba(0, 0, 0, 1)">;
 @import </span>'@assets/css/reset.scss'<span style="color: rgba(0, 0, 0, 1)">;
 @import </span>'@assets/css/layout.scss'<span style="color: rgba(0, 0, 0, 1)">;
 @import </span>'@assets/fonts/iconfont.css'<span style="color: rgba(0, 0, 0, 1)">;
</span>

<script context="module">
 export function load({ error, status }) {
 return {
 props: { error, status }
 }
 }
script>

<script>
 import Navbar from '$lib/Navbar'

 export let status
 export let error

 function goBack() {
 history.go(-1)
 }
script>

<svelte:head>
 <title>404错误title>
svelte:head>

<Navbar title="Page Error!!!" />

<div class="sv\_\_scrollview flex1">
 <div class="sv\_\_page-error flexbox flex-col flex-alignc flex-justifyc">
 <div class="sv\_\_page-error-img">
 <img src="404.png" alt="" />
 div>
 <div class="sv\_\_page-error-content">
 <div class="c-red fs-36">┗| {status} |┛ 嗷~~div>
 <div class="c-999 mt-10">{error.message}div>
 <div class="mt-20 sv\_\_btn sv\_\_btn-default" on:click={goBack}><i class="iconfont icon-arrL">i> 返回首页div>
 div>
 div>
div>

◆ Svelte.js状态管理+本地存储

svelte框架也提供了创建状态管理svelte/store,配置localStorage本地化存储服务。

/**
 * Svelte状态管理
*/

import { writable } from 'svelte/store'

const createStore = (value, key) => {
 const { subscribe, set, update } = writable(value)
 return {
 // 持久化存储
        useStorage: () => {
 const data = localStorage.getItem(key)
 if(data) {
 set(JSON.parse(data))
 }
 // 订阅
            subscribe(val => {
 [null, undefined].includes(val) ? localStorage.removeItem(key) : localStorage.setItem(key, JSON.stringify(val))
 })
 },
 subscribe,
 set,
 update,
 }
}

export const userinfo = createStore(localStorage.getItem('userinfo')||null, 'userinfo')

◆ Svelte.js实现仿朋友圈下拉刷新

使用 svelte.js+mescroll 实现仿朋友圈下拉转圈功能。

8ef67de959bb4dad89da6568d4afda13 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App


<script>
 import { onMount } from 'svelte'
 import Navbar from '$lib/Navbar'

 import MeScroll from 'mescroll.js/mescroll.min.js'
 import 'mescroll.js/mescroll.min.css'
 onMount(() => {
 let mescroll = new MeScroll('mescroll', {
 down: {
 auto: false,
 offset: 40,
 callback: downCallback
 },
 // up: {
            // callback: upCallback
            // }
 })
 // 下拉刷新的回调
        function downCallback() {
 console.log('下拉刷新...')
 setTimeout(() => {
 // 隐藏下拉刷新的状态;
 mescroll.endSuccess()
 }, 2000)
 }
 // 上拉加载的回调 page = {num:1, size:10}; num:当前页 默认从1开始, size:每页数据条数,默认10
        function upCallback(page) {
 console.log('上拉加载...')
 var pageNum = page.num; // 页码, 默认从1开始
            var pageSize = page.size; // 页长, 默认每页10条
 }
 })

 // ...
script>

<Navbar title="朋友圈" center transparent>
 <svelte:fragment slot="right">
 <div><i class="iconfont icon-tupian">i>div>
 <div class="ml-30"><i class="iconfont icon-fabu">i>div>
 svelte:fragment>
Navbar>

<div class="sv\_\_scrollview flex1">
 <div id="mescroll" class="mescroll">
 <div>
 <div class="sv\_\_uzone">
 ...
 div>
 div>
 div>
div>

◆ Svelte实现聊天功能

聊天页面文本框支持文字+emoj混排,光标处插入表情、网址/图片/视频预览、红包等功能。并且底部文本框单独抽离了一个editor.svelte组件。

a109ccc7ecd615f726b8e5c949e452d8 - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

<script>
    /**
 * @Desc Svelte.js实现聊天框组件
 * @Time andy by 2021-01
 * @About Q:282310962 wx:xy190310
 */

    // 编辑器内容
 export let editor

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

 let editorNode
 let lastCursor = null

    // 获取光标最后位置
    function getLastCursor() {
 let sel = window.getSelection()
 if(sel && sel.rangeCount > 0) {
 return sel.getRangeAt(0)
 }
 }

 // 光标位置插入内容
 export async function addHtmlInCursor(html) {
 // ...
 }

 // 删除编辑器内容
 export async function deleteHtml() {
 let range
 let sel = window.getSelection()
 if(lastCursor) {
 sel.removeAllRanges()
 sel.addRange(lastCursor)
 }
 range = getLastCursor()
 range.collapse(false)
 document.execCommand('delete')

 await tick()
 editorNode.blur()
 }

 function handleInput() {
 editor = editorNode.innerHTML
 lastCursor = getLastCursor()
 }

 function handleClick() {
 dispatch('click')
 lastCursor = getLastCursor()
 }

 function handleFocus() {
 dispatch('focus')
 lastCursor = getLastCursor()
 }

 function handleBlur() {
 dispatch('blur')
 }
script>

<div
 class="editor"
 bind:this={editorNode}
 contenteditable="true"
 bind:innerHTML={editor}
 on:input={handleInput}
 on:click={handleClick}
 on:focus={handleFocus}
 on:blur={handleBlur}
 style="user-select: text; -webkit-user-select: text;"
>div>

以上就是基于svelte.js+svelteKit开发仿微信app界面聊天实例的一些分享,希望对大家有所帮助!

最后附上一个uniapp+uview-ui开发移动端后台管理系统

https://blog.csdn.net/xiaoyan2017/p/15836112.html

6f557f75e234aad96f787da2d2c4041d - Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

转载请注明:xuhss » Svelte3聊天室|svelte+svelteKit仿微信聊天实例|svelte.js开发App

喜欢 (1)

您必须 登录 才能发表评论!