利用油猴插件 Tampermonkey 编写脚本以屏蔽网页指定元素——以屏蔽百度搜索右边的百度热榜为例

一、起因

一直使用 Tampermonkey 中的

AC-baidu-重定向优化百度搜狗谷歌必应搜索_favicon_双列

这个插件屏蔽好好的,今天突然屏蔽不了,正好自己编写一个简单的插件试试完成这一效果,如下图
在这里插入图片描述

二、过程
  • Tampermonkey 版本 v4.11
  1. 直接进入油猴管理面板,点击已安装脚本的左边的 + 号,这样就新建了一个新的用户脚本了
    在这里插入图片描述
  2. 我们审查原始得知百度搜索中我们需要屏蔽的元素块 id 块名为 content_right ,并且在网页测试可以用 display : none 属性屏蔽,那代码就很简单了
  • name 指代你的脚本名称
  • namespace 命名空间,可以用你自定义名称
  • version 脚本当前版本,这样别人如果使用了你的脚本,还可以及时更新
  • description 脚本的描述
  • author 作者名
  • match 脚本在匹配到什么url 时才触发生效
// ==UserScript==
// @name        自定义的屏蔽百度搜索结果中右侧百度热榜
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  屏蔽百度搜索的百度热榜
// @author        mizuhokaga
// @match        *://www.baidu.com/*
// @grant        none
// ==/UserScript==

(function() {
	//1.原生js写法
   //let content_right=document.getElementById("content_right");
   //if(content_right!=null){ content_right.style.display="none";}
	//2.jQuery写法,油猴现在已经支持jQuery了
	 $('#content_right').hide();
})();

需要注意的是油猴的元数据@match 中填入需要屏蔽的 url ,
我懒的想百度搜索的 url 是怎么匹配的就直接 * 通配了
除了用元数据匹配,也可以编辑右边的设置中包括/排除自行添加
在这里插入图片描述
3. 在油猴的管理面板确认是否打开自定义的脚本,然后看看效果,基本符合需求
在这里插入图片描述

三、场后反思

问题:

  1. 能不能更加精准的匹配的 url 吗?
  2. 测试效果后发现,网页还是先会出现百度热榜再消失,即闪屏现象,如何解决?
四、解决提出的问题

这里匹配 url 无关紧要,所以只需要解决第二个问题,闪屏的问题很容易想到是百度在这里做了异步加载,所以思路基本有了:我们需要监听页面变化事件,然后判断有没有该网页元素再是否隐藏。

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值