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高级程序设计
Dec 29 Javascript
JavaScript中数组的排序、乱序和搜索实现代码
Nov 30 Javascript
javascript的数据类型、字面量、变量介绍
May 23 Javascript
JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)
Oct 17 Javascript
JavaScript动态修改弹出窗口大小的方法
Apr 06 Javascript
jQuery插件pagination实现分页特效
Apr 12 Javascript
vue实现简单表格组件实例详解
Apr 16 Javascript
详解AngularJS用Interceptors来统一处理HTTP请求和响应
Jun 08 Javascript
解决vue js IOS H5focus无法自动弹出键盘的问题
Aug 30 Javascript
layer.alert自定义关闭回调事件的方法
Sep 27 Javascript
详解vue或uni-app的跨域问题解决方案
Feb 21 Javascript
vue如何清除浏览器历史栈
May 25 Vue.js
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生成静态页面详解
2006/12/05 PHP
PHP截取汉字乱码问题解决方法mb_substr函数的应用
2008/03/30 PHP
PHP二维数组的去重问题解析
2011/07/17 PHP
php修改NetBeans默认字体的大小
2013/07/02 PHP
php生成随机颜色方法汇总
2014/12/03 PHP
js实现同一页面多个运动效果的方法
2015/04/10 Javascript
使用Chrome浏览器调试AngularJS应用的方法
2015/06/18 Javascript
JQuery中ajax方法访问web服务实例
2015/07/18 Javascript
详解javascript实现瀑布流列式布局
2016/01/29 Javascript
Node.js中路径处理模块path详解
2016/11/14 Javascript
JS实现的系统调色板完整实例
2016/12/21 Javascript
Mongoose学习全面理解(推荐)
2017/01/21 Javascript
详解AngularJs ui-router 路由的简单介绍
2017/04/26 Javascript
JavaScript创建对象的七种方式全面总结
2017/08/21 Javascript
JS 中document.write()的用法和清空的原因浅析
2017/12/04 Javascript
Vue二次封装axios为插件使用详解
2018/05/21 Javascript
vue 解决路由只变化参数页面组件不更新问题
2019/11/05 Javascript
JavaScript实现好看的跟随彩色气泡效果
2020/02/06 Javascript
python 读取竖线分隔符的文本方法
2018/12/20 Python
Python利用WMI实现ping命令的例子
2019/08/14 Python
Numpy对数组的操作:创建、变形(升降维等)、计算、取值、复制、分割、合并
2019/08/28 Python
django创建超级用户时指定添加其它字段方式
2020/05/14 Python
python 实现Requests发送带cookies的请求
2021/02/08 Python
Hotels.com香港酒店网:你的自由行酒店订房专家
2018/01/22 全球购物
Booking.com英国官网:全球酒店在线预订网站
2018/04/21 全球购物
自我评价个人范文
2013/12/16 职场文书
初一地理教学反思
2014/01/16 职场文书
研修心得体会
2014/09/04 职场文书
民主评议党员自我评议范文2014
2014/09/26 职场文书
董事长岗位职责
2015/02/13 职场文书
上帝也疯狂观后感
2015/06/09 职场文书
退伍军人感言
2015/08/01 职场文书
2016年清明节网上祭英烈活动总结
2016/04/01 职场文书
python中sqllite插入numpy数组到数据库的实现方法
2021/06/21 Python
Oracle中update和select 关联操作
2022/01/18 Oracle
Python实现归一化算法详情
2022/03/18 Python