当前位置: 首页 > news >正文

前端油猴脚本开发小技巧笔记

  • 调试模式下,单击选中某dom代码,控制台里可以用$0访问到该dom对象。

  • $0.__vue___ 可以访问到该dom对应的vue对象。

  • jquery 对象 a,a[0]是对应的原生dom对象,$(原生对象) 得到对应的 jquery 对象。

  • jquery 选择器,加空格是匹配下一级,紧密排列是且,[a=b]匹配属性。jquery对象find可以继续筛选下一级。

  • 控制台直接输入函数名,可以打印出该函数的代码,继续点击代码可以跳转到对应的代码位置。

  • 查找某个按钮绑定的vue原始函数,可以通过1、2、5来找。

  • 监听属性

    1. function spyObjSetter(obj, prop, func, spyId) {const propertyName = Object.getOwnPropertyDescriptor(obj, prop);var setter = propertyName.set;if(spyId && propertyName.set['spyId'] == spyId) {return;}var proObj = {set(value) {var old = obj[prop];setter.call(obj, value);if(old != value) {func(old, value);}}}if(spyId) {proObj.set['spyId'] = spyId;}Object.defineProperty(obj, prop, proObj);
      }function spyObjGetter(obj, prop, func) {const propertyName = Object.getOwnPropertyDescriptor(obj, prop);var getter = propertyName.get;Object.defineProperty(obj, prop, {get() {getter.call(obj);func();}});
      }
  • 监听函数

      Function.prototype.after = function(fun){var self = this;return function(){var agent = self.apply(this,arguments);fun.apply(this,arguments);return agent;}}Function.prototype.before = function(fun){var self = this;return function(){fun.apply(this,arguments);var agent = self.apply(this,arguments);return agent;}}getUser = getUser.before(function(){//代码}).after(function(){//代码})
  • setTimeout这么写 setTimeout(function(){vueAopOne()}, 500);    

  • 无法监听的到值可以无脑setTimeout低配替代。

  • 查找某个按钮绑定事件是哪个函数,可以某个执行位置打断点,然后向上查找调用栈,再利用5查找。

  • vue对象可以通过parent和child来寻找指定对象。

  • vue代码method里的方法位置是vue对象的根目录,data里的变量也是。

  • vue.$opition.propsData 是属性位置。

http://www.lryc.cn/news/139934.html

相关文章:

  • 软考高级系统架构设计师系列之:搭建论文写作的万能模版
  • 多线程常见面试题
  • Java接收json参数
  • 赤峰100吨每天医院污水处理设备产品特点
  • nodejs+vue+elementui健身房教练预约管理系统nt5mp
  • 视频分割合并工具说明
  • 2023java面试深入探析Nginx的处理流程
  • Java的锁大全
  • Leetcode80. 删除有序数组中的重复项 II
  • 电脑显示“Operating System not found”该怎么办?
  • 简析SCTP开发指南
  • 把Android手机变成电脑摄像头
  • Linux线程篇(中)
  • 深度学习优化入门:Momentum、RMSProp 和 Adam
  • LeetCode 面试题 01.09. 字符串轮转
  • 系统上线安全测评需要做哪些内容?
  • vue 中 axios 的安装及使用
  • 数据结构——线性数据结构(数组,链表,栈,队列)
  • 多态(C++)
  • 算法leetcode|73. 矩阵置零(rust重拳出击)
  • axios 二次封装
  • Rust安全之数值
  • 4种方法实现html 页面内锚点定位及跳转
  • gitlab配置备忘
  • 基于Centos搭建k8s仓库
  • 浅谈泛在电力物联网发展形态与技术挑战
  • git reset --soft 用法
  • 哪些测试仪器可以用于检测静电中和设备的性能
  • 浅析 GlusterFS 与 JuiceFS 的架构异同
  • ARM开发,stm32mp157a-A7核PWM实验(驱动蜂鸣器,风扇,马达工作)