仿微信朋友圈项目梳理(1),参考资料的格式怎么写

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

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

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

  • 判断用户如果没有登录跳转到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中的方法来改变本地的头像地址 同样请求体中还是使用对象的深拷贝

4.2 修改用户昵称

在这里插入图片描述

  • 点击用户昵称时会跳转页面

  • 点击提交按钮 验证文本框内容不能为空

  • 请求后端接口修改数据库中的昵称

  • 成功后通过store中的方法修改本地昵称

  • 最后将文本框内容清空,提示修改成功,2秒后跳转至个人中心

4.3 更换/发表用户个性签名

文末

技术是没有终点的,也是学不完的,最重要的是活着、不秃。

零基础入门的时候看书还是看视频,我觉得成年人,何必做选择题呢,两个都要。喜欢看书就看书,喜欢看视频就看视频。

最重要的是在自学的过程中,一定不要眼高手低,要实战,把学到的技术投入到项目当中,解决问题,之后进一步锤炼自己的技术。

自学最怕的就是缺乏自驱力,一定要自律,杜绝“三天打鱼两天晒网”,到最后白忙活一场。

高度自律的同时,要保持耐心,不抛弃不放弃,切勿自怨自艾,每天给自己一点点鼓励,学习的劲头就会很足,不容易犯困。

技术学到手后,找工作的时候一定要好好准备一份简历,不要无头苍蝇一样去海投简历,容易“竹篮打水一场空”。好好的准备一下简历,毕竟是找工作的敲门砖。

拿到面试邀请后,在面试的过程中一定要大大方方,尽力把自己学到的知识舒适地表达出来,不要因为是自学就不够自信,给面试官一个好的印象,面试成功的几率就会大很多,加油吧,骚年!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

技术是没有终点的,也是学不完的,最重要的是活着、不秃。

零基础入门的时候看书还是看视频,我觉得成年人,何必做选择题呢,两个都要。喜欢看书就看书,喜欢看视频就看视频。

最重要的是在自学的过程中,一定不要眼高手低,要实战,把学到的技术投入到项目当中,解决问题,之后进一步锤炼自己的技术。

自学最怕的就是缺乏自驱力,一定要自律,杜绝“三天打鱼两天晒网”,到最后白忙活一场。

高度自律的同时,要保持耐心,不抛弃不放弃,切勿自怨自艾,每天给自己一点点鼓励,学习的劲头就会很足,不容易犯困。

技术学到手后,找工作的时候一定要好好准备一份简历,不要无头苍蝇一样去海投简历,容易“竹篮打水一场空”。好好的准备一下简历,毕竟是找工作的敲门砖。

拿到面试邀请后,在面试的过程中一定要大大方方,尽力把自己学到的知识舒适地表达出来,不要因为是自学就不够自信,给面试官一个好的印象,面试成功的几率就会大很多,加油吧,骚年!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-ThVZrDmk-1713453959250)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 9
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值