700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > JS仿今日头条手机端主页界面

JS仿今日头条手机端主页界面

时间:2024-03-05 07:41:01

相关推荐

JS仿今日头条手机端主页界面

web前端|js教程

javascript,界面,主页

web前端-js教程前言

论文源码下载,VScode F5默认,top用法ubuntu,tomcat++文档过多,居家黑色爬虫,php5 教程 pdf,中山品牌seo推广哪家好,dede网站演示,科技 模板lzw

vue也弄了一段时间了, 前段时间一直想用vue写个移动端,加之年底也不是很忙,于是前几天便着手开始弄了,到今天为止也算是勉强能看了

oa源码现在,在ubuntu上装jdk,网页爬虫监控数据,php,seo和esolzw

因为也是纯粹的写写前端页面,所以数据方面用的是mock.js,为了真实的模拟请求,可以直接在 Easy Mock 自己生成API

也可直接登陆我这项目的Easy Mock账号密码:

360导航源码,vscode换语言不提示了,ubuntu 进入单用户,tomcat管道模式,sqlite导出apk,济宁网页设计,云服务器天租,eclipse源码插件,前端框架分析,饿了吗爬虫,php活动,济南做seo排名,springboot外部化,网站首页弹出公告代码,八字算命网页链接,一号点模板,js 后台管理,考试页面html模板,通达oacrm客户管理系统增强版,安装织梦程序lzw

账号: vue-toutiao

密码: 123456

如果你想修改接口,请copy一份在修改

如果你想后台接口也自己开发的话。可以阅读我这篇博客 Vue + Node + Mongodb 开发一个完整博客流程

技术栈:

vue + webpack + vuex + axios

结构:

build: webpack配置

config: 项目配置参数

src

assets: 静态资源文件,存放图片啥的

components: 常用组件。例如 弹窗 等等。。。

directive: 常用指令封装

router: 路由表

store: 状态管理 vuex

styles: 样式文件

utils: 常用工具类封装

views: 视图页面

static: 静态文件: 存放 favicon.ico 等等

此项目用到了 DllPlugin 进行打包处理,所有启动该项目时记得,先执行一次该脚本命令生成配置

效果演示:

几个常用的知识点

1. 路由懒加载

{ path: /development, name: development, component: (resolve) => { require([../views/development.vue], resolve) }}

const _import_ = file => () => import(views/ + file + .vue){ path: /development, name: development, component: _import_(development)}

2. 登陆拦截

通过路由的 beforeEach 钩子函数来判断是否需要登陆

// 如:系统设置需要登陆{ path: /system, name: 系统设置, meta: {login: true }, component: _import_(System/index)}router.beforeEach((to, from, next) => { if (to.meta.login) { //判断前往的界面是否需要登陆 if (store.state.user.user.name) { // 是否已经登陆next() }else{Vue.prototype.$alert(请先登录!) .then( () => {store.state.user.isLogin = true }) } }else{ if (to.meta.page) store.state.app.pageLoading = true next() } })

3. 动画切换

通过检测设置在 Router上的animate属性 来判断它做什么样的切换动画

Router.prototype.animate = 0// 获取每个路由meta上面的slide 来判断它做什么动画{ path: /system, name: 系统设置, meta: {slide: 1 }, component: _import_(System/index)}watch: { $route (to, from) { /* 0: 不做动画 1: 左切换 2: 右切换 3: 上切换 4: 下切换 ...*/ let animate = this.$router.animate || to.meta.slide if (!animate) {this.animate = \}else{this.animate = animate === 1 ? slide-left : animate === 2 ? slide-right : animate === 3 ? slide-top : animate === 4 ? slide-bottom : \ } this.$router.animate = 0 }}

4. 视频播放

因为在IOS上 无法隐藏video的controls ,所以我们可以隐藏video,通过绘制canvas来达到播放视频的效果

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。