仿微信朋友圈项目梳理

在这里插入图片描述

  • 点击取消后选框消失

  • 点击从相册选择 会通过ref属性 用代码进行对uploader中的单击事件的触发

  • 我们将weui-uploader这模块隐藏不显示

  • 但uploader被单击时会执行像主题3.3中的步骤进行图片的上传

onSuccess: function (ret) {

// 更换用户的背景图像

self.submit(ret)

}

  • 上传成功后我们会触发submit函数并且将ret图片的信息作为参数进行传递

async submit (obj) {

// 更新数据库中的背景图像

const res = await service.post(‘users/update’, {

userId: this.$store.state.currentUser._id,

bgurl: obj.data.url

})

// 更新本地中的北背景图像

if (res.data.code === 0) {

this.$store.dispatch(‘setUser’, {

…this.$store.state.currentUser,

bgurl: obj.data.url

})

}

  • 通过调用接口 更新用户的背景图 成功后我们将调用store中的方法改变本地的背景图

  • 在调用store中的方法时我们传过去的参数中是运用对象的深拷贝(…)

2.1.3 点击头像进入用户中心
  • 判断用户如果没有登录跳转到login登录页面如果已经登录跳转到个人中心页面

  • 个人中心功能见主题4

2.2 下半部分

在这里插入图片描述

  • 动态列表

  • 点赞评论

  • 头像点击查看对方信息

  • 图片的查看

2.2.1 动态列表
  • 显示的头像信息 昵称

  • 显示帖子的内容(如果文字较多设置只显示三行超出隐藏)

overflow: hidden;

text-overflow: ellipsis;

display: -webkit-box;

-webkit-line-clamp: 3;

-webkit-box-orient: vertical;

  • 显示动态中携带的图片(一张图片按照图片的最长边进行成比例缩放,,多张图片按照固定宽高设置)

<img v-for=“imgInfo in data.picList”

:key=“imgInfo.id”

:preview=“data._id”

:src=“imgInfo.url”

class=“img-warp”>

<img

:src=“data.picList[0].url”

class=“img-warp-one”

:preview=“data._id”

:style=“initImgSize(data.picList[0])”>

  • 帖子的发表时间,通过moment来进行时间格式化
2.2.2 点赞评论
  • 点赞

  • 用户点击 - - 的时候 出现点赞评论的标识

  • 当该用户已经点过赞时,显示取消点赞,用户未点赞时,显示点赞

  • 点赞宇取消点赞都是用过点击时判断点赞还是取消来请求后端的不同接口进行修改

  • 成功后也要修改store中的本地数据

  • 评论

  • 获取当前手指的坐标 并触发bus中的showInput事件

addComment (e) {

// 获取当前点击的坐标

this.data.pageY = e.pageY

this.data.clientY = e.clientY

this. b u s . bus. bus.emit(‘showInput’, this.data)

}

  • 当用户触发showInput事件后显示文本框

  • 通过os进行检测用户的手机系统评论的文本框也是不同的

this. b u s . bus. bus.on(‘showInput’, (currentData) => {

if (this.$refs.inputBar) {

// 显示输入框

this.showInput = true

// 调用输入框组件的focusInput事件,以弹起键盘

this.$refs.inputBar.focusInput(currentData)

// this.$refs.inputWrap.style.top = currentData.pageY + ‘px’

// 调整页面的位置

if (os.isIOS) {

this.$refs.inputWrap.style.top = currentData.pageY + ‘px’

// 计算页面的滚动距离

setTimeout(() => {

const y = currentData.pageY - window.keyboradHeight

window.scroll(0, y)

}, 300)

}

}

})

  • 调用输入框组件的focusInput事件,以弹起键盘

  • 调整页面的位置

  • 计算页面的滚动距离

2.2.3 点击图片查看大图

在这里插入图片描述

  • 通过使用preview来实现图片的查看

  • preview作为元素的动态属性 值为每组图片公共值 这里使用发表用户的_id

  • 可以左右滑动进行切换图片

2.2.4 点击头像查看作者信息
  • 点击自己的头像则会跳转到主题4

  • 点击其他作者的头像则会跳转到用户信息(传递用户id在路径中)

在这里插入图片描述

  • 通过传递过来的id进行查寻用户信息在此进行展示

  • 点击发消息跳转到聊天页面(传递参数用户id用户昵称到路径中)主题5

2.3 上划加载更多

2.4 下拉更新

3. 发表动态页面


在这里插入图片描述

3.1 第一部分(取消发表按钮)

3.1.1 取消按钮————回到上一页面
3.1.2 发布按钮
  • 验证文字是否为空

  • 文字的数量是否合法

  • 请求接口进行发布

  • 成功后会跳转到主页(见主题2)

3.2 第二部分(文本区域)

3.2.1 用户输入的文字数量
  • 将展示用户输入文字数量使用动态数据,通过input事件实时得到文字数量不断改变变量的值
3.2.2 限定用户输入的文字数量为100
  • 采用weui中的form文本域

  • 通过双向绑定的元素得知用户输入的文字数量,当用户输入的文字数量超过100时,获取文字的内容通过substr属性取前一百个文字复制给双向绑定的文字内容的变量造成超出100字不能输入的现象。

3.3 第三部分(上传图片)

3.3.1 采用weui中的uploader技术进行图片的上传

在weui中的this指向并不是Vue实例所以在第一行中加入const self=this 让self常量指向我们的Vue实例

const self = this

weui.uploader(‘#uploader’, {

url: service.baseURL + ‘/post/uploadimg’,

auto: true,

type: ‘file’,

fileVal: ‘image’,

compress: {

width: 1600,

height: 1600,

quality: 0.8

},

onBeforeQueued: function (files) {

// this 是轮询到的文件, files 是所有文件

if ([‘image/jpg’, ‘image/jpeg’, ‘image/png’, ‘image/gif’].indexOf(this.type) < 0) {

weui.alert(‘请上传符合条件的图片’)

return false // 阻止文件添加

}

if (this.size > 10 * 1024 * 1024) {

weui.alert(‘请上传不超过10M的图片’)

return false

}

// 控制多元每次不能超过五张

if (files.length > self.totalUploadCount) {

weui.alert(‘最多只能上传’ + self.totalUploadCount + ‘张图片,请重新选择’)

return false

}

// 如果已经上传五张图片 作为不能继续上传

if (self.uploadCount + 1 > self.totalUploadCount) {

weui.alert(‘最多只能上传’ + self.totalUploadCount + ‘张图片’)

return false

}

self.uploadCount++

// return true; // 阻止默认行为,不插入预览图的框架

},

onBeforeSend: function (data, headers) {

const token = document.cookie.split(‘=’)[1]

headers[‘wec-access-token’] = token

},

onProgress: function (procent) {

// console.log(this, procent)

// return true; // 阻止默认行为,不使用默认的进度显示

},

onSuccess: function (ret) {

ret.data.id = this.id

self.picList.push(ret.data)

},

onError: function (err) {

console.log(‘error:’ + err)

// return true; // 阻止默认行为,不使用默认的失败态

}

})

  • onBeforeQueued

选择要上传的图片时触发(验证图片是否符合要求)

  • 验证图片的格式

  • 验证图片的大小不能超过10M

  • 控制每次选择图片不能超过五张

  • 控制如果已经选择五中图片不能继续上传

  • onBeforeSend

图片上传前触发

  • 我们将用户登录成功后存入Local Storage中的cuser(token)放到请求头headers中

  • onSuccess

图片上传成功后触发

  • 将图片的id存到 ret.data中

  • 将图片的所有信息添加到picList数组中

3.3.2 查看图片

在这里插入图片描述

在这里插入图片描述

  • 点击小图片时可以展现大图 点击图片时会通过e.target拿到事件源

  • 通过getAttribute(‘style’)方法获取style中属性background-image: url(“blob:http://192.168.0.107:8080/c1e0e8bf-4ac6-4184-a839-0cdcce473aa4”);

  • 通过“ " ”进行分割得到第二个元素 也就是路径

  • 将得到的路径复制给weui.gallery 他具有两个参数,一个是图片的路径,一个是删除图片我们在第二个参数中调用删除图片的函数并且将图片的信息以及查看大图的 div作为参数传递过去(见主题3.3.3)(self指向的是this Vue的实例)

preImg (e) {

const self = this

const url = e.target.getAttribute(‘style’).split(‘"’)[1]

var gallery = weui.gallery(url, {

onDelete: function () {

self.deleteImg(e.target, gallery)

}

})

}

3.3.3 删除图片

deleteImg (target, gallery) {

const self = this

weui.confirm(‘确认删除图片吗’, () => {

const id = target.getAttribute(‘data-id’)

const index = self.picList.findIndex(item => {

return item.id === id

})

self.picList.splice(index, 1)

// 删除对应的DOM元素

target.remove()

self.uploadCount–

})

gallery.hide(function () {

console.log(‘galleryhas been hidden’)

})

}

  • 运用weui中的confirm确定是否对删除图片

  • 确定删除:通过id找出picList数组中与之相同的图片信息进行删除,同时将对应的DOM元素进行删除

  • 上面执行的同时会执行hide事件,将我们现实大图的div进行隐藏

4. 用户个人中心


在这里插入图片描述

  • 导航部分为公用组件 通过父子组件prop进行传值(头部导航的文字内容)

  • 点击<按钮跳转上一页面

4.1 更换头像
  • 点击用户的头像时 依靠ref属性使用代码触发隐藏的上传图片插件的单击事件,进而激活uploader进行图片的上传

  • 上传成功后分为以下两步

onSuccess: async function (ret) {

// console.log(ret)

const res = await service.post(‘users/update’, {

userId: self.$store.state.currentUser._id,

avatar: ret.data.url

})

if (res.data.code === 0) {

self.$store.dispatch(‘setUser’, {

…self.$store.state.currentUser,

avatar: ret.data.url

})

weui.toast(‘上传成功’, 2000)

}

}

  • 上传下成功后在此函数中ret中就是上传成功图片的所有信息

  • 访问接口并且将用户id从store中取出以及图片的地址一并放到请求体中 更新数据库中的头像

  • 数据库中的数据更新成功后 会通过调用store中的方法来改变本地的头像地址 同样请求体中还是使用对象的深拷贝
    自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)


前端面试题汇总


前端面试题是我面试过程中遇到的面试题,每一次面试后我都会复盘总结。我做了一个整理,并且在技术博客找到了专业的解答,大家可以参考下:

由于篇幅有限,只能分享部分面试题,完整版面试题及答案可以【点击我】阅读下载哦~无偿分享给大家

感悟

录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-AlFi8tMy-1713660344324)]
前端面试题汇总


前端面试题是我面试过程中遇到的面试题,每一次面试后我都会复盘总结。我做了一个整理,并且在技术博客找到了专业的解答,大家可以参考下:

由于篇幅有限,只能分享部分面试题,完整版面试题及答案可以【点击我】阅读下载哦~无偿分享给大家

感悟

春招面试的后期,运气和实力都很重要,自己也是运气比较好,为了回馈粉丝朋友们(毕竟自己也玩了这么久哈哈哈),整理个人感悟和总结以上。最后祝愿大家能够收获理想offer!!

  • 11
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值