Nuxt.js实现校验访问浏览器类型的中间件


Posted in Javascript onAugust 24, 2018

前言

Nuxt.js 十分简单易用。一个简单的项目只需将 nuxt 添加为依赖组件即可。

这个需求非常常见,分享出去的页面的有时候在手机访问,有时候别人是PC打开的;

若是不是共享同一个页面的情况,就需要拦截跳转了;

当然你要共享同一个页面也可以(放大化到PC也需要添加某些CSS,也需判断设备)

思路

本质上还是校验 UA , 只是这次是从 req 拿到,而不是从客户端获取再做处理

客户端的处理的姿势

window.navigator.userAgent

服务端的处理姿势

其实基本和上面的思路一样的,只是我们能做处理的时间提前了

不用等到客户端页面渲染完毕后,再去判断,再做处理

用户的体验上会好很多

理清了逻辑我们就可以开始写了

谈谈Nuxt生命周期

Nuxt.js 就是一个Vue的服务端渲染框架,和React的服务端渲染框架 Next.js 类似,我们这里使用的版本是 v1.4.2 (默认初始化版本是基于 Express 的),让我们看官方给出的 Nuxt 执行生命周期流程

Nuxt.js实现校验访问浏览器类型的中间件 

render(渲染) 之前有几个阶段,通用全局配置均在 middleware(中间件) 阶段

那为什么不在 nuxtServerInit 去做一些处理,因为这里只能触发 store 的 action

代码实现

这里已经假设你已经大体看完官方文档,对于目录结构什么都了解为前提!

deviceType.js(utils目录)
// 这里的判断类型是自己整理的,覆盖面只涵盖我工作领域的
// 可以按需追加
/**
 *
 * @param {*} UA ,就是userAgent
 * @returns type: 设备类型
 *      env: 访问环境(微信/微博/qq)
 *      masklayer: 就是给外部拿到判断是否显示遮罩层的,一些特殊环境要引导用户到外部去打开访问
 */
function isWechat(UA) {
 return /MicroMessenger/i.test(UA) ? true : false;
}
function isWeibo(UA) {
 return /Weibo/i.test(UA) ? true : false;
}
function isQQ(UA) {
 return /QQ/i.test(UA) ? true : false;
}
function isMoible(UA) {
 return /(Android|webOS|iPhone|iPod|tablet|BlackBerry|Mobile)/i.test(UA)
  ? true
  : false;
}
function isIOS(UA) {
 return /iPhone|iPad|iPod/i.test(UA) ? true : false;
}
function isAndroid(UA) {
 return /Android/i.test(UA) ? true : false;
}

export function deviceType(UA) {
 if (isMoible(UA)) {
  if (isIOS(UA)) {
   if (isWechat(UA)) {
    return {
     type: "ios",
     env: "wechat",
     masklayer: true,
    };
   }
   if (isWeibo(UA)) {
    return {
     type: "ios",
     env: "weibo",
     masklayer: true,
    };
   }
   if (isQQ(UA)) {
    return {
     type: "ios",
     env: "qq",
     masklayer: true,
    };
   }
   return {
    type: "ios",
   };
  }
  if (isAndroid(UA)) {
   if (isWechat(UA)) {
    return {
     type: "android",
     env: "wechat",
     masklayer: true,
    };
   }
   if (isWeibo(UA)) {
    return {
     type: "android",
     env: "weibo",
     masklayer: true,
    };
   }
   if (isQQ(UA)) {
    return {
     type: "android",
     env: "qq",
     masklayer: true,
    };
   }
   return {
    type: "android",
   };
  }

  return {
   type: "mobile",
  };
 } else {
  return {
   type: "pc",
  };
 }
}

device.js(middleware目录)

// @ts-nocheck
import { deviceType } from "~/utils/deviceType";
export default function(context) {
 // @ts-ignore
 context.userAgent = process.server
  ? context.req.headers["user-agent"]
  : navigator.userAgent;
 // 给全局上下文添加一个属性来保存我们返回的匹配信息
 context.deviceType = deviceType(context.userAgent);
 // 这里注入到store,是因为我部分页面需要判断机型请求不同的数据,
 // 你们没有用到的话可以移除
 context.store.commit("SetDeviceType", context.deviceType);

 // 若是判断UA非移动端的,就在这里做处理了..
 // context.redirect(status,url) 这个可以重定向到外部网站
 // 若是内部访问可以直接用router对象push
 if (context.deviceType.type === "pc") {
  // context.redirect(301,'https://wwww.baidu.com')
 }
}
nuxt.config.js

这种功能是面向全站的,所以要注入到全局,所以页面都默认执行

往router注入中间件即可全局生效

module.exports = {
 router: {
  middleware: ["device"],
 },
};

总结

以上所述是小编给大家介绍的Nuxt.js实现校验访问浏览器类型的中间件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript prototype 使用介绍
Aug 29 Javascript
Extjs改变树节点的勾选状态点击按钮将复选框去掉
Nov 14 Javascript
JavaScript Math.floor方法(对数值向下取整)
Jan 09 Javascript
JavaScript访问字符串中单个字符的两种方法
Jul 03 Javascript
Bootstrap fileinput组件封装及使用详解
Mar 10 Javascript
JavaScript设计模式之代理模式详解
Jun 09 Javascript
jQuery实现table中两列CheckBox只能选中一个的示例
Sep 22 jQuery
jQuery实现基本隐藏与显示效果的方法详解
Sep 05 jQuery
JavaScript 复制对象与Object.assign方法无法实现深复制
Nov 02 Javascript
微信小程序通过一个json实现分享朋友圈图片
Sep 03 Javascript
vuejs+element UI table表格中实现禁用部分复选框的方法
Sep 20 Javascript
JavaScript setInterval()与setTimeout()计时器
Dec 27 Javascript
vue中使用gojs/jointjs的示例代码
Aug 24 #Javascript
vue操作下拉选择器获取选择的数据的id方法
Aug 24 #Javascript
浅谈Vue组件及组件的注册方法
Aug 24 #Javascript
JavaScript中this关键字用法实例分析
Aug 24 #Javascript
vue2.0 element-ui中el-select选择器无法显示选中的内容(解决方法)
Aug 24 #Javascript
JavaScript原型链与继承操作实例总结
Aug 24 #Javascript
element-ui循环显示radio控件信息的方法
Aug 24 #Javascript
You might like
再次研究下cache_lite
2007/02/14 PHP
php实现的一个很好用HTML解析器类可用于采集数据
2013/09/23 PHP
phpmyadmin提示The mbstring extension is missing的解决方法
2014/12/17 PHP
windows server 2008/2012安装php iis7 mysql环境搭建教程
2016/06/30 PHP
Centos 6.5系统下编译安装PHP 7.0.13的方法
2016/12/19 PHP
ThinkPHP5.1表单令牌Token失效问题的解决
2019/03/22 PHP
通过PHP的Wrapper无缝迁移原有项目到新服务的实现方法
2020/04/02 PHP
3款实用的在线JS代码工具(国外)
2012/03/15 Javascript
使用jquery动态加载Js文件和Css文件
2015/10/24 Javascript
详解基于Bootstrap扁平化的后台框架Ace
2015/11/27 Javascript
jQuery实现多级联动下拉列表查询框
2016/01/18 Javascript
js构造函数创建对象是否加new问题
2018/01/22 Javascript
基于express中路由规则及获取请求参数的方法
2018/03/12 Javascript
jQuery实现的隔行变色功能【案例】
2019/02/18 jQuery
nodejs实现获取本地文件夹下图片信息功能示例
2019/06/22 NodeJs
原生js实现针对Dom节点的CRUD操作示例
2019/08/26 Javascript
JS实现滚动条触底加载更多
2019/09/19 Javascript
Python应用03 使用PyQT制作视频播放器实例
2016/12/07 Python
Python使用functools实现注解同步方法
2018/02/06 Python
Python使用selenium实现网页用户名 密码 验证码自动登录功能
2018/05/16 Python
python使用turtle库与random库绘制雪花
2018/06/22 Python
Django框架自定义session处理操作示例
2019/05/27 Python
Python 使用 docopt 解析json参数文件过程讲解
2019/08/13 Python
Python中使用gflags实例及原理解析
2019/12/13 Python
python cv2在验证码识别中应用实例解析
2019/12/25 Python
django实现将修改好的新模型写入数据库
2020/03/31 Python
Python将二维列表list的数据输出(TXT,Excel)
2020/04/23 Python
Python语言编写智力问答小游戏功能
2020/10/13 Python
Bose美国官网:购买Bose耳机和音箱
2019/03/10 全球购物
Java servlet面试题
2012/03/04 面试题
实习评语大全
2014/04/26 职场文书
七一党日活动总结
2014/07/08 职场文书
个人批评与自我批评范文
2014/10/17 职场文书
2019年二手房买卖合同范本
2019/10/14 职场文书
React-vscode使用jsx语法的问题及解决方法
2021/06/21 Javascript
MySQL令人大跌眼镜的隐式转换
2021/08/23 MySQL