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 相关文章推荐
检测jQuery.js是否已加载的判断代码
May 20 Javascript
纯js和css实现渐变色包括静态渐变和动态渐变
May 29 Javascript
js跨域问题浅析及解决方法优缺点对比
Nov 08 Javascript
深入理解JavaScript中为什么string可以拥有方法
May 24 Javascript
BootStrap 附加导航组件
Jul 22 Javascript
jQuery Mobile和HTML5开发App推广注册页
Nov 07 Javascript
jQuery中select与datalist制作下拉菜单时的区别浅析
Dec 30 Javascript
es6 字符串String的扩展(实例讲解)
Aug 03 Javascript
Webpack 之 babel-loader文件预处理器详解
Mar 23 Javascript
详解基于DllPlugin和DllReferencePlugin的webpack构建优化
Jun 28 Javascript
Vue+webpack+Element 兼容问题总结(小结)
Aug 16 Javascript
使用Layui搭建后台管理界面的操作方法
Sep 20 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 expects parameter 1 to be resource, array given 错误
2011/03/23 PHP
Zend Framework教程之Autoloading用法详解
2016/03/08 PHP
Laravel框架Eloquent ORM删除数据操作示例
2019/12/03 PHP
使javascript也能包含文件
2006/10/26 Javascript
jQuery创建平滑的页面滚动(顶部或底部)
2013/02/26 Javascript
jQuery :first选择器使用介绍
2013/08/09 Javascript
JS操作数据库的实例代码
2013/10/17 Javascript
判定是否原生方法的JS代码
2013/11/12 Javascript
解决用jquery load加载页面到div时,不执行页面js的问题
2014/02/22 Javascript
jQuery/CSS3图片特效插件整理推荐
2014/12/07 Javascript
jQuery过滤特殊字符及JS字符串转为数字
2016/05/26 Javascript
需要牢记的JavaScript基础知识
2016/09/25 Javascript
AngularJS 与百度地图的结合实例
2016/10/20 Javascript
vue+axios实现登录拦截的实例代码
2017/05/22 Javascript
详解vue2.0 transition 多个元素嵌套使用过渡
2017/06/19 Javascript
Vue单文件组件基础模板小结
2017/08/10 Javascript
Vue.js 2.x之组件的定义和注册图文详解
2018/06/19 Javascript
vue中动态设置meta标签和title标签的方法
2018/07/11 Javascript
详解JavaScript中的坐标和距离
2019/05/27 Javascript
[56:18]DOTA2上海特级锦标赛主赛事日 - 4 败者组第四轮#2 MVP.Phx VS Fnatic第二局
2016/03/05 DOTA
Pandas之DataFrame对象的列和索引之间的转化
2019/06/25 Python
django基于restframework的CBV封装详解
2019/08/08 Python
Python图像处理二值化方法实例汇总
2020/07/24 Python
用python制作个视频下载器
2021/02/01 Python
使用HTML5和CSS3表单验证功能
2017/05/05 HTML / CSS
欧洲领先的火车票和大巴票预订平台:Trainline
2018/12/26 全球购物
Wedgwood英国官方网站:英式精致骨瓷餐具、礼品与生活精品,源于1759年
2019/09/02 全球购物
什么是事务?为什么需要事务?
2012/01/09 面试题
中专生自荐信
2013/10/12 职场文书
自主招生自荐书
2013/11/29 职场文书
个人简历自我评价
2014/01/06 职场文书
优秀求职信范文分享
2014/01/26 职场文书
《诺贝尔》教学反思
2014/02/17 职场文书
大学新生军训自我鉴定范文
2014/09/13 职场文书
中学生秋季运动会广播稿
2014/09/21 职场文书
幼儿园音乐教学反思
2016/02/18 职场文书