vuejs에서 채팅 인터페이스를 구현하는 방법
vuejs에서 채팅 인터페이스를 구현하는 방법: 1. "npm install"을 실행하여 종속성을 설치합니다. 2. "scrollLoader.vue"를 통해 데이터 스크롤 로딩을 구현합니다. 3. main.js를 수정합니다. .vue.Can.
이 기사의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.
vuejs에서 채팅 인터페이스를 구현하는 방법은 무엇입니까?
Vue.js는 WeChat 채팅 창 표시 구성 요소 기능을 모방합니다
소스 코드: https://github.com/doterlin/vue-wxChat
데모 주소: https://doterlin.github.io/vue- wxChat /
Run
# install dependencies npm install # serve with hot reload at localhost:8080 npm run dev # build for production with minification npm run build
Introduction
- 은 텍스트 및 사진 표시를 지원합니다(음성 카테고리 표시는 향후 지원 예정).
- 스크롤 로딩이 내 또 다른 구성 요소인 scrollLoader.vue("Vue.js 위아래 스크롤 로딩 구성 요소")에 의존하는 데이터의 스크롤 로딩을 지원합니다.
- QQ 이모티콘을 지원하려면 v-emotion 명령을 전역적으로 등록하세요. 코드는 다음과 같습니다.
function toEmotion(text, isNoGif){ var list = ['微笑', '撇嘴', '色', '发呆', '得意', '流泪', '害羞', '闭嘴', '睡', '大哭', '尴尬', '发怒', '调皮', '呲牙', '惊讶', '难过', '酷', '冷汗', '抓狂', '吐', '偷笑', '愉快', '白眼', '傲慢', '饥饿', '困', '惊恐', '流汗', '憨笑', '大兵', '奋斗', '咒骂', '疑问', '嘘', '晕', '折磨', '衰', '骷髅', '敲打', '再见', '擦汗', '抠鼻', '鼓掌', '糗大了', '坏笑', '左哼哼', '右哼哼', '哈欠', '鄙视', '委屈', '快哭了', '阴险', '亲亲', '吓', '可怜', '菜刀', '西瓜', '啤酒', '篮球', '乒乓', '咖啡', '饭', '猪头', '玫瑰', '凋谢', '示爱', '爱心', '心碎', '蛋糕', '闪电', '炸弹', '刀', '足球', '瓢虫', '便便', '月亮', '太阳', '礼物', '拥抱', '强', '弱', '握手', '胜利', '抱拳', '勾引', '拳头', '差劲', '爱你', 'NO', 'OK', '爱情', '飞吻', '跳跳', '发抖', '怄火', '转圈', '磕头', '回头', '跳绳', '挥手', '激动', '街舞', '献吻', '左太极', '右太极', '嘿哈', '捂脸', '奸笑', '机智', '皱眉', '耶', '红包', '鸡']; if (!text) { return text; } text = text.replace(/\[[\u4E00-\u9FA5]{1,3}\]/gi, function(word){ var newWord = word.replace(/\[|\]/gi,''); var index = list.indexOf(newWord); var backgroundPositionX = -index * 24 var imgHTML = ''; if(index<0){ return word; } if (isNoGif) { if(index>104){ return word; } imgHTML = `<i class="static-emotion" style="background:url(https://res.wx.qq.com/mpres/htmledition/images/icon/emotion/default218877.gif) ${backgroundPositionX}px 0;"></i>` } else { var path = index>104 ? '/img' : 'https://res.wx.qq.com/mpres/htmledition/images/icon'; imgHTML = `` } return imgHTML; }); return text; } Vue.directive('emotion', { bind: function (el, binding) { el.innerHTML = toEmotion(binding.value) } });
사용 방법은?
매개변수는 구성요소 설명에 설정되었으며 App.vue
에 설명되어 있습니다.
매개변수 및 설명:
WeChat 채팅 시각적 구성요소
는 v-emotion 명령에 따라 달라지는 scrollLoader 구성요소에 따라 다릅니다(main.js 참조). 구현용)
매개변수 :
width 구성 요소 너비, 기본값 450
wrapBg 외부 부모 요소 배경색, 기본값 #efefef
maxHeight 표시 창 최대 높이, 기본값 900
contactAvatarUrl 친구 아바타 url
ownerAvatarUrl WeChat 소유자 아바타 url
ownerNickname WeChat 소유자의 닉네임
getUpperData (필수) 상단으로 스크롤할 때 데이터를 로드하는 방법 반환 값은 Promise 객체여야 합니다. 해결 구조는 data
getUnderData( 필수) 하단으로 스크롤 시 데이터를 로딩하는 방식은 위와 동일합니다.
data(필수) 초기화 데이터를 전달하며, 구조는 다음과 같습니다.
[{ direction: 2, //为2表示微信主人发出的消息,1表示联系人 id: 1, //根据这个来排序消息 type: 1, //1为文本,2为图片 content: '你好!![呲牙]', //当type为1时这里是文本消息,当type2为2时这里要存放图片地址;后续会支持语音的显示 ctime: new Date().toLocaleString() //显示当前消息的发送时间 }, { direction: 1, id: 2, type: 1, content: '你也好。[害羞]', ctime: new Date().toLocaleString() }]
전체 사용 예
효과: https://doterlin.github.io/vue-wxChat/
코드:
//主文件,对wxChat的用法做示例 <template> <wxChat :data="wxChatData" :showShade="false" contactNickname="简叔" :getUpperData="getUpperData" :getUnderData="getUnderData" :ownerAvatarUrl="ownerAvatarUrl" :contactAvatarUrl="contactAvatarUrl" :width="420"> </wxChat> </template> <script> import wxChat from './components/wxChat.vue' export default { name: 'app', data () { return { upperTimes: 0, underTimes: 0, upperId: 0, underId: 6, ownerAvatarUrl: './src/assets/avatar1.png', contactAvatarUrl: './src/assets/avatar2.png', wxChatData: [{ direction: 2, id: 1, type: 1, content: '你好!![呲牙]', ctime: new Date().toLocaleString() }, { direction: 1, id: 2, type: 1, content: '你也好。[害羞]', ctime: new Date().toLocaleString() }, { direction: 2, id: 3, type: 1, content: '这是我的简历头像:', ctime: new Date().toLocaleString() }, { direction: 2, id: 4, type: 2, content: './src/assets/wyz.jpg', ctime: new Date().toLocaleString() }, { direction: 1, id: 5, type: 1, content: '你开心就好。[微笑]', ctime: new Date().toLocaleString() }] } }, components:{wxChat}, methods:{ //向上滚动加载数据 getUpperData(){ var me = this; // 这里为模拟异步加载数据 // 实际上你可能要这么写: // return axios.get('xxx').then(function(result){ // return result; //result的格式需要类似下面resolve里面的数组 // }) return new Promise(function(resolve){ setTimeout(function(){ //模拟加载完毕 if(me.upperTimes>3){ return resolve([]); } //加载数据 resolve([{ direction: 2, id: me.upperId-1, type: 1, content: '向上滚动加载第 ' + me.upperTimes +' 条!', ctime: new Date().toLocaleString() }, { direction: 1, id: me.upperId-2, type: 1, content: '向上滚动加载第 ' + me.upperTimes +' 条!', ctime: new Date().toLocaleString() }] ) }, 1000); me.upperId= me.upperId+2; me.upperTimes++; }) }, getUnderData(){ var me = this; //意义同getUpperData() return new Promise(function(resolve){ setTimeout(function(){ //模拟加载完毕 if(me.underTimes>3){ return resolve([]); } //加载数据 resolve( [{ direction: 1, id: me.underId+1, type: 1, content: '向下滚动加载第 ' + me.underTimes +' 条!', ctime: new Date().toLocaleString() }, { direction: 2, id: me.underId+2, type: 1, content: '向下滚动加载第 ' + me.underTimes +' 条!', ctime: new Date().toLocaleString() }] ) }, 1000); me.underId = me.underId+2; me.underTimes++; }) } } } </script> <style> *{ margin: 0; padding: 0; } #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } h1, h2 { font-weight: normal; } ul { list-style-type: none; padding: 0; } li { display: inline-block; } </style>
시작에 오신 것을 환영합니다:
https://github.com/doterlin/vue-wxChat
추천: " 5개의 vue.js 비디오 튜토리얼 중 최신 선택"
위 내용은 vuejs에서 채팅 인터페이스를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Vue.js 및 Kotlin 언어를 사용하여 Android 애플리케이션을 개발하기 위한 몇 가지 팁 모바일 애플리케이션의 인기와 사용자 요구의 지속적인 증가로 인해 Android 애플리케이션 개발은 개발자들로부터 점점 더 많은 관심을 끌고 있습니다. Android 앱을 개발할 때 올바른 기술 스택을 선택하는 것이 중요합니다. 최근 몇 년 동안 Vue.js와 Kotlin 언어는 점차 Android 애플리케이션 개발에 널리 사용되는 언어가 되었습니다. 이 기사에서는 Vue.js 및 Kotlin 언어를 사용하여 Android 애플리케이션을 개발하는 몇 가지 기술을 소개하고 해당 코드 예제를 제공합니다. 1. 초기에 개발 환경을 설정한다

Vue.js 및 Python을 사용하여 데이터 시각화 애플리케이션을 개발하기 위한 몇 가지 팁 소개: 빅 데이터 시대의 도래와 함께 데이터 시각화는 중요한 솔루션이 되었습니다. 데이터 시각화 애플리케이션 개발에서 Vue.js와 Python의 조합은 유연성과 강력한 기능을 제공할 수 있습니다. 이 기사에서는 Vue.js 및 Python을 사용하여 데이터 시각화 애플리케이션을 개발하기 위한 몇 가지 팁을 공유하고 해당 코드 예제를 첨부합니다. 1. Vue.js 소개 Vue.js는 경량 JavaScript입니다.

Vue.js와 Lua 언어의 통합, 게임 개발을 위한 프런트엔드 엔진 구축을 위한 모범 사례 및 경험 공유 소개: 게임 개발이 지속적으로 발전함에 따라 게임 프런트엔드 엔진의 선택이 중요한 결정이 되었습니다. 이러한 선택 중에서 Vue.js 프레임워크와 Lua 언어는 많은 개발자의 초점이 되었습니다. 널리 사용되는 프런트엔드 프레임워크인 Vue.js는 풍부한 생태계와 편리한 개발 방법을 갖추고 있으며, Lua 언어는 가볍고 효율적인 성능으로 인해 게임 개발에 널리 사용됩니다. 이 기사에서는 다음 방법을 살펴보겠습니다.

Vue.js와 Objective-C 언어의 통합, 안정적인 Mac 애플리케이션 개발을 위한 팁 및 제안 최근 몇 년 동안 프런트 엔드 개발에서 Vue.js의 인기와 Mac 애플리케이션 개발에서 Objective-C의 안정성으로 인해 개발자는 시작합니다. 보다 안정적이고 효율적인 Mac 응용 프로그램을 개발하기 위해 두 가지를 결합하려고 합니다. 이 기사에서는 개발자가 Vue.js와 Objective-C를 올바르게 통합하고 고품질 Mac 애플리케이션을 개발하는 데 도움이 되는 몇 가지 팁과 제안을 소개합니다. 하나

Vue를 사용하여 QQ와 같은 채팅 버블 효과를 구현하는 방법 오늘날 소셜 시대에 채팅 기능은 모바일 애플리케이션과 웹 애플리케이션의 핵심 기능 중 하나가 되었습니다. 채팅 인터페이스의 가장 일반적인 요소 중 하나는 채팅 풍선입니다. 이는 발신자와 수신자의 메시지를 명확하게 구분하여 메시지의 가독성을 효과적으로 향상시킬 수 있습니다. 이 글에서는 Vue를 사용하여 QQ와 유사한 채팅 풍선 효과를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저 채팅 풍선을 나타내는 Vue 구성 요소를 만들어야 합니다. 구성 요소는 두 가지 주요 부분으로 구성됩니다.

PHP 및 Vue.js를 사용하여 차트에서 데이터 필터링 및 정렬 기능을 구현하는 방법 웹 개발에서 차트는 데이터를 표시하는 매우 일반적인 방법입니다. 차트의 데이터 필터링 및 정렬 기능은 PHP 및 Vue.js를 사용하여 쉽게 구현할 수 있으므로 사용자는 차트의 데이터 보기를 사용자 정의하고 데이터 시각화 및 사용자 경험을 향상시킬 수 있습니다. 먼저 차트에서 사용할 데이터 세트를 준비해야 합니다. 이름, 나이, 학년이라는 세 개의 열을 포함하는 데이터 테이블이 있다고 가정합니다. 데이터는 이름, 나이, 학년 Zhang San 1890 Li입니다.

Vue.js 및 Perl 언어를 사용하여 효율적인 웹 크롤러 및 데이터 스크래핑 도구를 개발하십시오. 최근 인터넷의 급속한 발전과 데이터의 중요성이 증가함에 따라 웹 크롤러 및 데이터 스크래핑 도구에 대한 수요도 증가했습니다. 이러한 맥락에서 Vue.js와 Perl 언어를 결합하여 효율적인 웹 크롤러와 데이터 스크래핑 도구를 개발하는 것은 좋은 선택입니다. 이 기사에서는 Vue.js 및 Perl 언어를 사용하여 이러한 도구를 개발하는 방법을 소개하고 해당 코드 예제를 첨부합니다. 1. Vue.js 및 Perl 언어 소개

Vue.js와 Dart 언어의 통합, 멋진 모바일 애플리케이션 UI 인터페이스 구축을 위한 실습 및 개발 기술 소개: 모바일 애플리케이션 개발에서 사용자 인터페이스(UI)의 디자인과 구현은 매우 중요한 부분입니다. 멋진 모바일 애플리케이션 인터페이스를 달성하기 위해 Vue.js를 Dart 언어와 통합하고 Vue.js의 강력한 데이터 바인딩 및 구성 요소화 기능과 Dart 언어의 풍부한 모바일 애플리케이션 개발 라이브러리를 사용하여 멋진 모바일 애플리케이션을 구축할 수 있습니다. UI 인터페이스. 이 기사에서는 다음 방법을 보여줍니다.
