当前位置: 首页 > 编程日记 > 正文

使用vue2.0 vue-router vuex 模拟ios7操作

其实你也可以,甚至做得更好...

首先看一下效果:用vue2.0实现SPA:模拟ios7操作 与 通讯录实现

  

  github地址是:https://github.com/QRL909109/ios7 如果您觉得可以,麻烦给一个star,支持我一下。

之前接触过Angular1.0,React,都只是学点入门,但对于Vue却觉得很容易上手,不止入门简单,插件也是很丰富的,脚手架也是便利的很...

项目分析:

1.首屏滑动解锁,并能移动小圆点

2.主屏幕  长按图标抖动,删除图标,点击小圆点的主屏幕 抖动停止

3.点击电话图标,进入电话模块

4.进入个人中心:点击编辑,移入删除图标,滑动出现删除;点击完成,删除图标消失

5.进入通讯录:右侧固定栏滑动 列表滑动到相应位置(使用better-scroll 插件)

6.进入拨号:拨号与删除

插件介绍:

vue-router: vue路由插件  vue-router 2.0 中文文档

vuex: vue状态管理 vuex 1.0 中文文档 方便组件共用状态

better-scroll: 优化滑动性能的插件

lib-flexible: 手淘移动端H5 终端适配

moment: 时间格式化插件

项目布局:

采用手淘的flexible   这里有学习资源  使用Flexible实现手淘H5页面的终端适配

要点:

1.根据手机dpr设置不同的scale,font-size (注意ios的dpr会适应变化,而Android的dpr一直为1)

2.整个屏幕宽度默认为10rem,采用750设计稿上下兼容,1rem = 75px

3.文字用px写,分别写出兼容

div{font-size:12px; 
}[data-dpr="2"]{font-size:24px;  
}[data-dpr="3"]{font-size:36px;  
}

4.采用flex弹性布局(注意兼容高低版本)

开始:(挑有用重点讲)

1、修改webpack.base.conf.js

利用webpack alias定义别名,方便输入路径,根据完整绝对地址

例如:

resolve: {extensions: ['', '.js', '.vue'],fallback: [path.join(__dirname, '../node_modules')], alias: {'vue$': 'vue/dist/vue','src': path.resolve(__dirname, '../src'),'assets': path.resolve(__dirname, '../src/assets'),'components': path.resolve(__dirname, '../src/components'),'store':path.resolve(__dirname,'../src/vuex/store'),'getters':path.resolve(__dirname,'../src/vuex/getters'),'actions':path.resolve(__dirname,'../src/vuex/actions'),'mock':path.resolve(__dirname,'../src/mock')}},

这样只要在任意位置使用 import ... from actions

webpack将会自动匹配actions的位置,不用再去计算文件位置,写出'../../../actions'。

2、配置路由:在src目录下新建 route-config.js 

const routes=[{path: '/main',name: 'main',meta: {title: '主页面'},component: resolve => {require(['./views/main.vue'], resolve)},children: [{path: '',name: 'personal',meta: {title: '个人收藏'},component: resolve => {require(['./views/phone/personal.vue'], resolve)},children:[phone_detail]}]},{.... },{path: '*',redirect: {name: 'main'}}   
];
export default routes 

这里采用异步组件,按需加载,使用webpack的代码分割功能。

路由机制是采用匹配规则,根据path匹配URL的路径,从而加载对应的组件。

这里稍微提一下vue-router 1.0 和 vue-router 2.0 写法的区别

vue-router1.0

传递vue-router实例,通过map进行定义路由映射

vue-router2.0

使用router 构造配置 routes

tips: 设置标题栏的title

通过vue-router实例后的afterEach,to能获取每个路由的状态,这时候便能使用document.title = to.meta.title (前提是router-config 里面有设置meta对象)

3、APP.vue结构

考虑到小圆点是所有页面都存在的,所以结构为router-view加载路由匹配页面,另外加载小圆点组件。

<template><div class="_full"><!-- app router --><transition name="bounce"><keep-alive><router-view></router-view></keep-alive></transition><!--小圆点--><topPoint></topPoint></div>
</template>

或许你有疑惑 keep-alive 加在这有什么用?

keep-alive 会缓存不活动的组件实例,而不是销毁它们。主要用于保留组件状态或避免重新渲染

在做“个人收藏”模块遇到很诡异的bug (没加 keep-alive)

刚开始能删除数据,但跳转到其他页面重新回来后,就不能执行删除了。

后面一分析才知道,在从其他页面跳转回来后,组件重新渲染,再次请求了列表数据,而页面的数据却缓存着,导致数据不一致。加入keep-alive就能保留组件状态

4、v-touch不兼容vue2.0解决方案

本以为应该会有插件支持的,结果没法找到,只能自己写简单指令识别下。(只支持长按 press,向上 swipeup,向下 swipedown,向左swipeleft,向右 swiperight)

使用 v-touch:swiperight="methodFunc"

vue指令 touch 使用bind,

  • binding.arg 获得传入模式
  • el 监听绑定的事件
  • binding.value 获得传入的事件

通过对touchstart touchmove touchend 的判断,执行对应的事件。

5、引入better-scroll插件

功能:优化滚动,能模仿像原生弹性的效果

使用:需要在外部包含固定高度的容器

<div ref="scrollWrapper"><ul><li v-for="item in List" class="commit-hook"></li>
   </ul>    
</div><script>import BScroll from 'better-scroll'
export default{created(){this.$nextTick(() => {  //这里需要异步this._initScroll();})},methods: {_initScroll(){this.containerScroll = new BScroll(this.$refs.scrollWrapper,{click:true   //可点击
                });}}
}
</script>

这样将会添加translate,使用贝塞尔曲线,达到原生效果。

如果需要实时知道滚动的区域,可以这么配置:

created(){this.$nextTick(() => {this._initScroll();this._calculateHeight()})
},
methods:{_initScroll(){this.containerScroll = new BScroll(this.$refs.scrollWrapper, {probeType: 3});this.containerScroll.on('scroll', (pos)=> {this.scrollY = Math.abs(Math.round(pos.y)); //实时获取Y轴的数值
            })}_calculateHeight(){let commitList = this.$refs.commitBox.getElementsByClassName('commit-hook'); //获取对应的DOM元素let height = 0;this.listHeight.push(height)for (let i = 0; i < commitList.length; i++) {let item = commitList[i]height += item.clientHeight;this.listHeight.push(height)}}
}
computed: {currentIndex(){                  //实时获得当前的区域for (let i = 0; i < this.listHeight.length; i++) {let height1 = this.listHeight[i];let height2 = this.listHeight[i + 1];if (!height2 || (this.scrollY >= height1 && this.scrollY < height2)) {return i;}}return 0;}
}

通过对比 v-for的  index 与 currentIndex 就能实时知道位置了。

6、组件间的通信

可以看看我的另一篇文章 vue2.0--组件通信(非vuex法)

主要用到父子 子父 通信方法,但为了方便项目使用 vuex状态管理。

以上的项目很基础,练习一遍,便能比我做的更好... 如有缺漏,做不好的地方,欢迎大家指正讨论。

如果您觉得有帮助,请star一下,给予我更好的支持。

github地址是:https://github.com/QRL909109/ios7

如需转载,请注明出处。

转载于:https://www.cnblogs.com/QRL909109/p/6143394.html

相关文章:

区块链技术是否会终结开源时代?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 2017年11月18~19日&#xff0c;在上海交大召开的2017中国开源年会&#xff0c;在第二天我们组织了一个“闭门会议”。在这个闭门会议上&#xff0c…

Direct2D开发:Direct2D 和 GDI 互操作性概述

本主题说明如何结合使用 Direct2D 和 GDI&#xff08;可能为英文网页&#xff09;。有两种方法可以结合使用 Direct2D 和 GDI&#xff1a;您可以将 GDI 内容写入与 Direct2D GDI 兼容的呈现器目标&#xff0c;也可以将 Direct2D 内容写入 GDI 设备上下文 (DC) 0X01 将Direct2D内…

vmware虚拟机启动centOs黑屏

如图所示 &#xff0c; 我的VM 启动虚拟机之后就变成了上面的样子&#xff0c;一直不动&#xff0c;ping也ping不好&#xff0c;这个时候 &#xff1a; 1. 要么 内存不够了&#xff1b; 2. 要么 网络协议存在问题了&#xff1b; 本地windows环境在管理员的cmd命令行输入 &…

plc和pc串口通讯接线_让你搞懂PLC串口通讯和通讯接口,这东西估计没几个能说清楚~...

电力作业人员在使用PLC的时候会接触到很多的通讯协议以及通讯接口&#xff0c;最基本的PLC串口通讯和基本的通讯接口你都了解吗&#xff1f;1&#xff0c;什么是串口通讯&#xff1f;串口是计算机上一种非常通用设备通信的协议(不要与通用串行总线Universal Serial Bus或者USB混…

西班牙放大招,利用区块链技术防腐

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 在过去十年来&#xff0c;西班牙爆发了一系列引人注目的腐败丑闻&#xff0c;其中以公共采购最甚。但据TI 2017年的腐败认知指数表明&#xff0c;西…

FreeBSD 8

FreeBSD 8.0的安装过程和7.2区别不大。先在FreeBSD官方网站上下载安装镜像&#xff0c;我一般都下载DVD的ISO&#xff0c;也有人爱好下最小的安装包&#xff0c;然后通过FTP或HTTP方式从网上下载各个程序包。这里就以DVD的ISO为例&#xff0c;下载DVD的ISO后&#xff0c;刻录到…

c潭州课堂25班:Ph201805201 MySQL第二课 (课堂笔记)

mysql> create table tb_2( -> id int, -> name varchar(10) not null -> ); 插入数据 insert into tb_2 value(1,xiaobai); 在非空时&#xff0c;NOT NULL 必须有值&#xff0c; 2&#xff0c;在已有的表中设置一个字段的非空约束 mysql> alter table tb_2 -…

vanpopup 高度_解决VantUI popup 弹窗不弹出或无蒙层的问题

背景####组件PopupTime.vue把vant官网的popup时间选择器抽成组件&#xff1a;popup1show: true 即弹窗显示:title"popupTitle.popupName"v-model"currentDate"type"datetime"cancel"onCancel" confirm"onConfirm" class&quo…

区块链技术入门,都涉及哪些编程语言?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 关于区块链的技能掌握&#xff0c;提到最多的就是Go语言和C、Java&#xff0c;但是很多人产生了歧义&#xff0c;认为只有这几种语言才可以&#x…

centos安装配置nginx,ssl生产和配置教程

【一】nginx安装nginx安装带ssl扩展&#xff1a; cd /usr/local/src #进入用户目录 wget http://nginx.org/download/nginx-1.15.0.tar.gz #下载最新版本nginx tar -zxvf nginx-1.15.0.tar.gz #解压 cd nginx-1.15.0 #进入目录 ./configure --prefix/opt/nginx --with-http_stu…

如何将github上的 lib fork之后通过podfile 改变更新源到自己fork的地址

解决办法: http://stackoverflow.com/questions/20936885/cocoapods-and-github-forks 就是fork完后&#xff0c;提交更改到自己的github上 然后修改podfile的pod导入方式 pod lib,:github>your fork lib.git,:commit >your commitid转载于:https://www.cnblogs.com/code…

证书 vivo_iQOO 5 Pro获泰尔实验室首张流畅性能体验五星证书

近日&#xff0c;中国泰尔实验室向vivo旗下的iQOO 5 Pro(V2025A)型号手机颁发了流畅性能体验五星证书。据中国泰尔实验室官方表示&#xff0c;这是“泰尔证书-流畅性能体验”测评方案推出后的首张证书。“泰尔证书-流畅性能体验”测评方案据悉&#xff0c;“泰尔证书-流畅性能体…

GUI编程之tkinter

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 0. 前言 本文内容为使用Python3的tkinter模块&#xff0c;开发GUI。在阅读本文前&#xff0c;请确保你已经或可能满足以下条件&#xff1a; 电脑中…

js插件 webp_(转)让浏览器支持Webp

转载自&#xff1a;https://segmentfault.com/a/1190000005898538?utm_sourcetuicool&utm_mediumreferral转换工具判断浏览器支持webP方法一&#xff1a;functioncheckWebp() {try{return (document.createElement(canvas).toDataURL(image/webp).indexOf(data:image/webp…

一些大佬博客里的个签

觉得很励志~遇到了就复制下来激励自己。 1.宜静默&#xff0c;宜从容&#xff0c;宜谨严&#xff0c;宜俭约。 //读了两遍感觉心都静下来了。 2.别打扰我&#xff0c;我还能写一套程序。 3.时间并不会因为你的迷茫和迟疑而停留&#xff0c;就在你看这篇文章的同时&#xff0c…

以太坊搭建私有链

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 1.关于私有链 在以太坊上部署智能合约、发起交易需要花费以太币。而私链和公有链没有关系&#xff0c;不用同步大量的数据&#xff0c;也不用花钱购…

C++回溯法走迷宫

1 #include <iostream> 2 #include <iomanip> 3 #include <cstdlib> 4 using namespace std;5 6 #define MaxSize 100 7 int maze[10][10] //定义一个迷宫&#xff0c;0表示通道&#xff0c;1表示墙 8 {9 { 1,1,1,1,1,1,1,1,1,1 },10 { 1,0,…

js放大镜特效

原理分析&#xff1a;当鼠标在小图片上移动时&#xff0c;通过捕捉鼠标在小图片上的位置&#xff0c;定位大图片的相应位置。&#xff08;同时&#xff0c;当鼠标在小图片上移动时&#xff0c;右侧大图片往相反的方向移动。&#xff09; 放大镜特效设计&#xff1a; ①页面元素…

5页面返回上个页面定位_5个步骤,画好页面流程图

对于任何产品设计来说&#xff0c;构建流程都是一个绕不开的环节。其奠定了后续的产品框架&#xff0c;是用户体验的基石。本文将从定义和方法出发&#xff0c;结合实际案例&#xff0c;深入浅出地阐述流程图的作用以及画法。最近在做一个关于阅读笔记的原型&#xff0c;业务流…

EOS智能合约:system系统合约源码分析

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 eosio.system 概览 笔者使用的IDE是VScode&#xff0c;首先来看eosio.system的源码结构。如下图所示。 本文分析的源码来自于eosio.contracts。 …

文字超过省略_从楚篆到楚玺的文字结构

从古文字研究的角度来说&#xff0c;楚玺文字也是楚文字系统中重要的组成部分。古文字发展演变的一般规律&#xff0c;如简化、繁化、异化、分化、类化等在印章上也有反映。在楚系简帛书没有大量出土发现和研究出版前&#xff0c;楚玺研究的文字参照物不多&#xff0c;主要是依…

caffe prototxt分析

测试用prototxt name: "CIFAR10_quick"layer {name: "data" type: "MemoryData" top: "data" top: "label" memory_data_param {batch_size: 1 #样本个数 channels: 3 height: 32 width: 32 }}layer {name: "conv1…

Mysql与Oracle区别

Mysql与Oracle区别 文章分类:数据库 周五去一家公司去面试&#xff0c;那公司经理问了关于Mysql与Oracle的区别问题&#xff0c;以前没有总结&#xff0c;回答也不是很好&#xff0c;只是凭感觉&#xff0c;先总结如下&#xff1a; 1. Oracle是大型数据库而Mysql是中小型数据库…

区块链 + 大数据:EOS存储

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 谈到区块链的存储&#xff0c;我们很容易联想到它的链式存储结构&#xff0c;然而区块链从比特币发展到今日当红的EOS&#xff0c;技术形态已经演化…

全网最全的Windows下Anaconda2 / Anaconda3里Python语言实现定时发送微信消息给好友或群里(图文详解)...

不多说&#xff0c;直接上干货&#xff01; 缘由&#xff1a; &#xff08;1&#xff09;最近看到情侣零点送祝福&#xff0c;感觉还是很浪漫的事情&#xff0c;相信有很多人熬夜为了给爱的人送上零点祝福&#xff0c;但是有时等着等着就睡着了或者时间并不是卡的那么准就有点强…

Agreeing to the Xcode/iOS license requires admin privileges, please re-run as root via sudo

更新了xcode后使用goland运行项目时提示 Agreeing to the Xcode/iOS license requires admin privileges, please re-run as root via sudo 更具提示打开xcode 点击agree安装即可&#xff01; 转载于:https://www.cnblogs.com/mafeng/p/6196494.html

arc diff 指定版本号_Phabricator客户端安装

前提需要配置好服务器端客户端安装mac环境下&#xff0c;指定一个目录$ mkdir somewhere/$ cd somewhere/somewhere/ $ git clone https://github.com/phacility/libphutil.gitsomewhere/ $ git clone https://github.com/phacility/arcanist.git配置环境变量&#xff0c;在.ba…

EOSIO 转帐详解

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 EOS和EOS的不同之处 在EOS网络中存在两种货币&#xff0c;一种是EOS&#xff0c;还有一种是EOS网络中的代币。说到这里大家似乎有点疑惑&#xff0…

各种函数调用约定及浮点数传参

32位下_stdcall, _fastcall, _cdecl #include <windows.h>int _stdcall Func1(int a, int b, int c, int d) {return abcd; } int _fastcall Func2(int a, int b, int c, int d) {return abcd; } int _cdecl Func3(int a, int b, int c, int d) {return a b c d; }…

cookie、session总结

前几天在调试第三方支付接口时碰到一个session失效问题&#xff0c;用了几天时间才搞明白&#xff0c;现在回想一下&#xff0c;主要还是由于cookie和session这一块的一些基本概念没有搞清楚&#xff0c;现总结一下。 浏览器使用HTTP协议作为应用层协议&#xff0c;而HTTP协议是…