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 getElementsByName()的用法说明
Jul 31 Javascript
JS中判断JSON数据是否存在某字段的方法
Mar 07 Javascript
js对象基础实例分析
Jan 13 Javascript
js实现鼠标点击左上角滑动菜单效果代码
Sep 06 Javascript
原生JS实现平滑回到顶部组件
Mar 16 Javascript
微信小程序  modal弹框组件详解
Oct 27 Javascript
ES6概念 Symbol.keyFor()方法
Dec 25 Javascript
webpack多页面开发实践
Dec 18 Javascript
JS+HTML实现的圆形可点击区域示例【3种方法】
Aug 01 Javascript
微信小程序8种数据通信的方式小结
Feb 03 Javascript
图解JS原型和原型链实现原理
Sep 15 Javascript
微信小程序实现锚点跳转
Nov 23 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
在PHP中养成7个面向对象的好习惯
2010/07/17 PHP
php实现文件下载(支持中文文名)
2013/12/04 PHP
PHP+Mysql基于事务处理实现转账功能的方法
2015/07/08 PHP
php自定义函数实现二维数组排序功能
2016/07/20 PHP
PHP+Apache环境中如何隐藏Apache版本
2017/11/24 PHP
Laravel5框架添加自定义辅助函数的方法
2018/08/01 PHP
HTML node相关的一些资料整理
2010/01/01 Javascript
JQuery 插件制作实践 xMarquee插件V1.0
2010/04/02 Javascript
js自定义事件及事件交互原理概述(一)
2013/02/01 Javascript
jQuery判断checkbox选中状态
2016/05/12 Javascript
Bootstrap 附加导航(Affix)插件实例详解
2016/06/01 Javascript
Bootstrap学习系列之使用 Bootstrap Typeahead 组件实现百度下拉效果
2016/07/07 Javascript
浅谈react 同构之样式直出
2017/11/07 Javascript
JavaScript队列结构Queue实现过程解析
2020/03/07 Javascript
OpenLayers3加载常用控件使用方法详解
2020/09/25 Javascript
[01:06:54]DOTA2-DPC中国联赛 正赛 RNG vs Dragon BO3 第一场 1月24日
2021/03/11 DOTA
Python内置的字符串处理函数详细整理(覆盖日常所用)
2014/08/19 Python
基于python实现的百度音乐下载器python pyqt改进版(附代码)
2019/08/05 Python
Python3加密解密库Crypto的RSA加解密和签名/验签实现方法实例
2020/02/11 Python
python json load json 数据后出现乱序的解决方案
2020/02/27 Python
Tensorflow之MNIST CNN实现并保存、加载模型
2020/06/17 Python
HTML5中新标签和常用标签详解
2014/03/07 HTML / CSS
阿里旅行:飞猪
2017/01/05 全球购物
汽车专业毕业生推荐信
2013/11/12 职场文书
会计专业应届生求职信
2013/11/24 职场文书
给学校的建议书
2014/03/12 职场文书
降消项目实施方案
2014/03/30 职场文书
启动仪式策划方案
2014/06/14 职场文书
关于读书的演讲稿400字
2014/08/27 职场文书
承诺书模板
2014/08/30 职场文书
升职自我推荐信范文
2015/03/25 职场文书
求职推荐信范文
2015/03/27 职场文书
安全教育观后感
2015/06/17 职场文书
使用react-virtualized实现图片动态高度长列表的问题
2021/05/28 Javascript
解析Redis Cluster原理
2021/06/21 Redis
“鬼灭之刃”热度不减,其成功背后的原因是什么?
2022/03/22 日漫