最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • next.js聊天实例|Next/React网页端仿微信

    正文概述 掘金(xiaoyan2015)   2020-12-28   423

    简介

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    支持拖拽图片至聊天区域发送、截图粘贴发送等功能。

    技术栈

    • 使用技术:next.js+react+Rredux
    • UI组件库:Antd (蚂蚁金服react组件库)
    • 字体图标:阿里iconfont图标库
    • 弹窗组件:RLayer(基于react自定义对话框)
    • 滚动条组件:RScroll(基于react自定义滚动条)

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    快速了解Next.js

    基于 React.js 服务端渲染的 SSR 开发框架。Next.js 预设了利用 react.js 开发服务端渲染的应用所需要的各种配置。让你的网页拥有SEO功能。

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    next官网:nextjs.org/

    next中文网:www.nextjs.cn/

    github地址:github.com/vercel/next…

    React.js自定义滚动条RScroll

    项目中用到的滚动条是基于react自定义美化滚动条_Rscroll.js_组件。

    next.js聊天实例|Next/React网页端仿微信

    next.js聊天实例|Next/React网页端仿微信

    Rscroll支持是否原生滚动、自动隐藏滚动条、尺寸/颜色等功能。

    React.js自定义对话框RLayer

    项目中用到的所有对话框是基于react自定义弹窗_RLayer.js_组件。

    next.js聊天实例|Next/React网页端仿微信

    Rscroll一款轻量级基于react.js开发的PC桌面端弹框组件。支持超过**30+**参数自由配置。

    大家可以去看看之前的这一篇分享文章。

    基于React.js网页版弹窗|react pc端自定义对话框组件RLayer

    公共布局模板

    Head组件用于配置一些页面信息,如:title、keyword、description及图标icon等信息。

    function Layout(props) {
        const router = useRouter()
    
        // 拦截验证
        useEffect(() => {
            // ...
        }, [])
    
        return (
        <>
            {/* 配置公共head信息 */}
            <Head>
                <title>Next.js聊天室</title>
                <link rel="icon" href="/favicon.ico" />
                <meta name="keywords" content="Next.js|React.js|Next.js聊天室|Next.js仿微信|React聊天实例"></meta>
                <meta name="description" content="Next-WebChat 基于Next.js+React+Redux构建的服务端渲染聊天应用程序"></meta>
            </Head>
    
            <div className="next__container flexbox flex-alignc flex-justifyc">
                <div className={utils.classNames('next__wrapper')} style={{ backgroundImage: `url(${props.skin})` }}>
                    <div className="next__board flexbox">
                        {/* 右上角按钮 */}
                        <WinBar {...props} />
    
                        {/* 侧边栏 */}
                        <Sidebar {...props} />
    
                        {/* 中间栏 */}
                        <Middle />
    
                        {/* 主体布局 */}
                        <div className="nt__mainbox flex1 flexbox flex-col">
                            {props.children}
                        </div>
                    </div>
                </div>
            </div>
        </>
        )
    }
    

    聊天模块

    编辑器支持光标处插入表情、粘贴截图发送、拖拽发送图片等功能。

    next.js聊天实例|Next/React网页端仿微信

    // react中实现div的contenteditable功能
    return (
        <div 
            ref={editorRef}
            className="editor"
            contentEditable="true"
            dangerouslySetInnerHTML={{__html: state.editorText}}
            onClick={handleClicked}
            onInput={handleInput}
            onFocus={handleFocus}
            onBlur={handleBlur}
            style={{userSelect: 'text', WebkitUserSelect: 'text'}}>
        </div>
    )
    
    handlePlayVideo = (item, e) => {
        rlayer({
            content: (
                <div className="flexbox flex-col" style={{height: '100%'}}>
                    <div className="ntDrag__head"><i className="iconfont icon-bofang"></i> 视频预览</div>
                    <div className="ntMain__cont flex1 flexbox flex-col">
                        {/* 视频video */}
                        <video className="vplayer" src={item.videosrc} poster={item.imgsrc} autoPlay preload="auto" controls
                            x5-video-player-fullscreen="true"
                            webkit-playsinline="true"
                            x-webkit-airplay="true"
                            playsInline
                            x5-playsinline="true"
                            style={{height: '100%', width: '100%', objectFit: 'contain', outline: 'none'}}
                        />
                    </div>
                </div>
            ),
            layerStyle: {background: '#f6f5ef'},
            opacity: .2,
            area: ['550px', '450px'],
            drag: '.ntDrag__head',
            resize: true,
            maximize: true,
        })
    }
    
    handleDragEnter = (e) => {
        e.stopPropagation()
        e.preventDefault()
    }
    handleDragOver = (e) => {
        e.stopPropagation()
        e.preventDefault()
    }
    handleDrop = (e) => {
        e.stopPropagation()
        e.preventDefault()
        console.log(e.dataTransfer)
    
        this.handleFileList(e.dataTransfer)
    }
    // 获取拖拽文件列表
    handleFileList = (filelist) => {
        let files = filelist.files
        if(files.length >= 2) {
            rlayer.message({icon: 'error', content: '暂时支持拖拽一张图片'})
            return false
        }
        for(let i = 0; i < files.length; i++) {
            if(files[i].type != '') {
                this.handleFileAdd(files[i])
            }else {
                rlayer.message({icon: 'error', content: '目前不支持文件夹拖拽功能'})
            }
        }
    }
    handleFileAdd = (file) => {
        if(file.type.indexOf('image') == -1) {
            rlayer.message({icon: 'error', content: '目前不支持非图片拖拽功能'})
        }else {
            let reader = new FileReader()
            reader.readAsDataURL(file)
            reader.onload = function() {
                let img = this.result
    
                console.log(img)
            }
        }
    }
    

    编辑框监听paste粘贴事件。

    /**
     * 编辑器模块
     * @Time     andy by 2020-12
     * @About    Q:282310962  wx:xy190310
     */
    
    import { useState, useRef, forwardRef, useEffect, useImperativeHandle } from 'react'
    
    const Editor = forwardRef(({value, onInput, onFocus, onBlur, onPaste}, ref) => {
        const [state, setState] = useState({
            editorText: value,
            // 记录最后光标位置
            lastRange: null
        })
        const editorRef = useRef()
    
        useEffect(() => {
            // 编辑器粘贴事件
            if(!editorRef.current) return
            editorRef.current.addEventListener('paste', function(e) {
                let cbd = e.clipboardData
                let ua = window.navigator.userAgent
                if(!(e.clipboardData && e.clipboardData.items)) return
    
                if(cbd.items && cbd.items.length === 2 && cbd.items[0].kind === "string" && cbd.items[1].kind === "file" &&
                    cbd.types && cbd.types.length === 2 && cbd.types[0] === "text/plain" && cbd.types[1] === "Files" &&
                    ua.match(/Macintosh/i) && Number(ua.match(/Chrome\/(\d{2})/i)[1]) < 49){
                    return;
                }
                for(var i = 0; i < cbd.items.length; i++) {
                    var item = cbd.items[i]
                    // console.log(item)
                    // console.log(item.kind)
                    if(item.kind == 'file') {
                        var blob = item.getAsFile()
                        if(blob.size === 0) return
                        // 读取图片记录
                        var reader = new FileReader()
                        reader.readAsDataURL(blob)
                        reader.onload = function() {
                            var _img = this.result
    
                            // 返回图片给父组件
                            typeof onPaste == 'function' && onPaste(_img)
                        }
                    }
                }
            })
        }, [])
        
        // ...
    })
    
    export default Editor
    

    好了,到这里基于Next.js开发聊天介绍差不多了。谢谢大家的阅读~~✍

    最后附上一个Nuxt.js项目

    Nuxt+Vue聊天室|nuxt仿微信App界面|nuxt.js聊天实例

    next.js聊天实例|Next/React网页端仿微信


    起源地下载网 » next.js聊天实例|Next/React网页端仿微信

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元