页面埋点H5 大数据uniapp 按需要更改代码就行

本文涉及的产品
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 页面埋点H5 大数据uniapp 按需要更改代码就行

页面埋点H5 大数据uniapp 按需要更改代码就行



逻辑思路 跳转页面前,记录当前页面的信息停留的时长以及各种信息,然后等走的时候再将记录的信息发送出去


1.记录当前页面信息的函数


//  埋点通用接口
// triggerType: 必传 类型 entryStr(进入) || leaveStr(离开) || String:自定义事件描述
// pageUrl:非必传,页面路径,不穿默认获取当前路径
//再洗一个触发事件
async function myMta(triggerType = "", pageUrl = '') {
  console.log('埋点', triggerType, pageUrl)
  let entryTime, leaveTime, stayTime, nowTime;
  // entryTime 进入页面时间
  // leaveTime 离开页面时间
  // stayTime  停留时长
  // nowTime   进行当前函数的时间
  if (!triggerType) return
  if (triggerType == 'entryStr') {
  entryTime = new Date().getTime();
  nowTime = new Date().getTime();
  leaveTime = null;
  uni.setStorageSync('entryTime', entryTime)
  } else {
  entryTime = uni.getStorageSync('entryTime');
  leaveTime = new Date().getTime();
  stayTime = leaveTime - entryTime;
  nowTime = new Date().getTime();
  }
  //异步请求当前网络信息是wifi还是啥
  uni.getNetworkType({
  success: function(res) {
    let networkType = res.networkType;
    let token, openid, sysTemInfo;
    try {
    uni.getStorage({
      key: 'storage_key',
      success: function(res) {
      token = res.data.token
      openid = res.data.openId
      uni.getSystemInfo({
        success: function(res) {
        sysTemInfo = res
        const urlArgs =
          getCurrentPageUrlWithArgs(); //通过这个函数获取当前页面的信息 如果想返回更多自己去函数里面更改
        var data = {
          token: token,
          openid: openid,
          triggerType: triggerType,
          networkType: networkType,
          pageInfo: {
          pageUrl: pageUrl,
          route: urlArgs.route,
          params: urlArgs.options,
          title: urlArgs.title,
          },
          entryTime: toDateDetail(entryTime),
          leaveTime: toDateDetail(leaveTime),
          nowTime: toDateDetail(nowTime),
          stayTime: stayTime,
          sysTemInfo: sysTemInfo,
          // ip: ip[0]
        }
        data = {
          token: token,
          openid: openid,
          triggerType: triggerType,
          networkType: networkType,
          pageInfo: JSON.stringify({
          pageUrl: pageUrl,
          route: urlArgs.route,
          params: urlArgs.options,
          title: urlArgs.title,
          }),
          entryTime: toDateDetail(entryTime),
          leaveTime: toDateDetail(leaveTime),
          nowTime: toDateDetail(nowTime),
          stayTime: stayTime,
          sysTemInfo: JSON.stringify(sysTemInfo),
          // ip: ip[0]
        }
        var headers = {};
        headers['X-Token'] = token
        uni.request({
          url: 'https://lingzhuang.gengduoke.com/adminapi/customtrajectory/save',
          data: data,
          header: headers,
          method: 'post',
          success: (res) => {
          console.log('res', res)
          },
          fail: (err) => {
          console.log('err', err)
          }
        })
        },
        fail(error) {
        sysTemInfo = 'null'
        }
      })
      },
      fail(error) {
      token = "null"
      }
    })
    } catch (e) {}
  }
  })
}
// 获取当前页面链接和参数
function getCurrentPageUrlWithArgs() {
  const pages = getCurrentPages();
  const currentPage = pages[pages.length - 1]; //当前页面的全部信息
  const route = currentPage.route; //当前路由的路径 pages/login/login
  const options = currentPage.options; //url里面的参数json类型
  const title = currentPage.$holder.navigationBarTitleText //当前页面的navigationBarTitleText
  /拼接路由url字符串开始///
  let urlWithArgs = `/${route}?`; //将url里面的参数拼接成字符串  /pages/login/login?a=1
  for (let key in options) {
  const value = options[key];
  urlWithArgs += `${key}=${value}&`;
  }
  urlWithArgs = urlWithArgs.substring(0, urlWithArgs.length - 1);
  /拼接路由url字符串结束///
  return {
  options, //当前页面的参数
  urlWithArgs, //当前页面的参数
  route,
  title
  };
}
function toDateDetail(number) {
  if (!number) number = new Date();
  // var n = number * 1000
  var date = new Date(number);
  var Y = date.getFullYear() + "-";
  var M =
  (date.getMonth() + 1 < 10 ?
    "0" + (date.getMonth() + 1) :
    date.getMonth() + 1) + "-";
  var D = date.getDate() < 10 ? "0" + date.getDate() : date.getDate();
  var h = date.getHours() < 10 ? "0" + date.getHours() : date.getHours();
  var mm = date.getMinutes() < 10 ? "0" + date.getMinutes() : date.getMinutes();
  var s = date.getSeconds() < 10 ? "0" + date.getSeconds() : date.getSeconds();
  return Y + "" + M + "" + D + " " + h + ":" + mm + ":" + s;
}
/**
 *   appId            ->      小程序ID             类型:String
 *   appToken         ->      自定义               类型:String
 *   token            ->      当前用户token        类型:String
 *   openid           ->      当前用户openid       类型:String
 *   triggerType      ->      事件类型             类型:String
 *   pageInfo {       ->      当前页面信息         类型:Object
 *     pageUrl:       ->      不带参数             类型:String
 *     url:           ->      带参数               类型:String
 *     ...params      ->      当前页面所有参数       类型:Object
 *   }
 *   entryTime        ->      进入页面时间          类型:Number
 *   leaveTime        ->      离开当前页面时间      类型:Number
 *   stayTime         ->      停留时长             类型:Number   单位:ms
 *   sysTemInfo       ->      设备信息             类型:Object
 */
export default {
  myMta
};


2.跳转进行路由拦截然后让他进行第一个里面的函数的操作


import Mta from "./myMta.js";
var nav = {
  navigateTo: ({
  url
  }) => {
  var link = getCurrentPages()[getCurrentPages().length - 1].route;
  Mta.myMta('leaveStr', link)
  console.log('navigateTo', link, '-', url)
  uni.navigateTo({
    url: url,
    success: function(res) {
    Mta.myMta('entryStr', url)
    }
  });
  },
  redirectTo: ({
  url
  }) => {
  var link = getCurrentPages()[getCurrentPages().length - 1].route;
  Mta.myMta('leaveStr', link)
  console.log('redirectTo', link, '-', url)
  uni.redirectTo({
    url: url,
    success: function(res) {
    Mta.myMta('entryStr', url)
    }
  });
  },
  reLaunch: ({
  url
  }) => {
  var link = getCurrentPages()[getCurrentPages().length - 1].route;
  Mta.myMta('leaveStr', link)
  console.log('reLaunch', link, '-', url)
  uni.reLaunch({
    url: url,
    success: function(res) {
    Mta.myMta('entryStr', url)
    }
  });
  },
  switchTab: ({
  url
  }) => {
  var link = getCurrentPages()[getCurrentPages().length - 1].route;
  Mta.myMta('leaveStr', link)
  console.log('switchTab', link, '-', url)
  uni.switchTab({
    url: url,
    success: function(res) {
    Mta.myMta('entryStr', url)
    }
  });
  },
  navigateBack: ({
  num
  }) => {
  var link = getCurrentPages()[getCurrentPages().length - 1].route;
  Mta.myMta('leaveStr', link)
  console.log('navigateBack', link, '-', num)
  uni.navigateBack({
    delta: num
  });
  },
  share:()=>{
  Mta.myMta('share')
  }
}
export default {
  ...nav
}

3.调用页面跳转以及函数监听和发送


this.nav.navigateTo({
    url:'/pages/login/login'
})


4.可以封装全局


页面埋点/
import nav from '@/utils/navRoute.js'
Vue.prototype.nav = nav
//1.navigateTo
//2.reLaunch
//3.switchTab
//4.navigateBack
相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps&nbsp;
目录
相关文章
|
26天前
|
数据采集 数据可视化 大数据
大数据体系知识学习(三):数据清洗_箱线图的概念以及代码实现
这篇文章介绍了如何使用Python中的matplotlib和numpy库来创建箱线图,以检测和处理数据集中的异常值。
37 1
大数据体系知识学习(三):数据清洗_箱线图的概念以及代码实现
|
8天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
8天前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
20天前
|
移动开发 Android开发 容器
uniapp中使用videojs构建H5直播播放器
【10月更文挑战第14天】这两天在开发H5直播带货功能模块,使用原生的video播放器播放不了m3u8的流地址,于是找了videojs,参考了网上的一些资料研究了一下,感觉还不错,videojs播放m3u8流地址还挺稳定的,下面就简单记录一下uniapp里面使用方式
|
22天前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
151 3
|
29天前
|
Web App开发 移动开发 前端开发
uniapp环境H5运行及发行(入门必学)
uniapp环境H5运行及发行(入门必学)
126 5
|
26天前
|
数据可视化 API
低代码可视化-uniapp购物车页面-代码生成器
低代码可视化-uniapp购物车页面-代码生成器
19 1
|
30天前
|
存储 缓存 分布式计算
大数据-89 Spark 集群 RDD 编程-高阶 编写代码、RDD依赖关系、RDD持久化/缓存
大数据-89 Spark 集群 RDD 编程-高阶 编写代码、RDD依赖关系、RDD持久化/缓存
41 4
|
1月前
|
消息中间件 存储 Java
大数据-58 Kafka 高级特性 消息发送02-自定义序列化器、自定义分区器 Java代码实现
大数据-58 Kafka 高级特性 消息发送02-自定义序列化器、自定义分区器 Java代码实现
41 3
|
1月前
|
消息中间件 Java 大数据
大数据-56 Kafka SpringBoot与Kafka 基础简单配置和使用 Java代码 POM文件
大数据-56 Kafka SpringBoot与Kafka 基础简单配置和使用 Java代码 POM文件
62 2