网站首页 > 技术文章 正文
我们在使用浏览器的过程中,免不了要用到各种类型的插件,比如要管理你的网站密码,屏蔽页面广告等,正是因为浏览器插件有如此广泛的应用,对于一个Web前端开发工程师来说,掌握Chrome浏览器开发更是必不可少的技能。
3月13日,我们邀请到腾讯TVP,日行一课联合创始人兼 CTO李艺老师,让他来讲讲,如何开发一款实现自动关点评收的Chrome插件,也就是说通过一个小小的Chrome插件在页面来实现自动关注、点赞、评论的功能。
Chrome浏览器插件工作机制
在实战之前,李艺老师先讲解了浏览器的工作机制,我们来看看是如何通过background、Popup、content script、Injected script这四个文件来实现整个点赞、关注、评论的功能的。
background是我们的后台脚本页面,在演示中,我们所看到的下面这个弹窗所打印出的信息所指向的就是这个background文件,它是在浏览器主线程内执行的程序,项目中所有的页面后台都有个background这个程序在运行
Popup是个JS脚本,主要实现下图中选择功能开始操作这个弹窗,在这个文件中我们定义个这个弹窗的的功能和样式
content script是内容脚本,通过这个脚本,我们可以在浏览器页面中实现所要注入脚本和样式,但content script只能共享页面本身存在的DOM节点,页面的JS变量是访问不到的。
与content script脚本相比,Injected script不仅可以访问页面的DOM节点,也可以访问页面的JS变量和方法
代码逻辑讲解
搞清楚了浏览器的工作机制后,李艺老师通过拉新和主动关注新粉两个功能来展开,通过代码逻辑讲解来向学员们展示,如何通过首页拉新,拉取db关注人数等方法来实现上面我们所说的这些功能。
现场手撕代码
代码逻辑讲解完毕后,李艺老师通过现场手撕代码来完成了学员现场提出新的需求,如何通过浏览器插件关注新粉丝,并保存到数据库中。
最后,我们来看下,在本地运行整个项目所需要的软件工具
- Install MySQL & workbench
- Install Golang,设置代理
- Download code & 修改昵称
- debug.sh,启动后端程序
- 在浏览器中安装插件
更多《Hello,World》免费公开课内容,请xv搜索【开课吧订阅号】获得
下期预告:Kubernetes实战!
你的点赞与关注 是小编坚持的动力。
- 上一篇: CAS中央认证服务
- 下一篇: 前端性能优化(三)——浏览器九大缓存方法
猜你喜欢
- 2024-12-07 先睹为快即将到来的HTML6
- 2024-12-07 浏览器储存(cookie,localStorage,sessionStorage,IndexDB)
- 2024-12-07 Cookie详解
- 2024-12-07 前端最能打的本地存储方案
- 2024-12-07 用JS超简单的修改和删除cookie
- 2024-12-07 前端性能优化(三)——浏览器九大缓存方法
你 发表评论:
欢迎- 最近发表
-
- 用AI做微信小程序的完整步骤_如何用ai制作微信表情包
- 自习室预约的微信小程序设计与实现-计算机毕业设计源码+LW文档
- 微信小程序开发入门指南_微信小程序开发入门教程
- 写字机器人好用吗? 组装就花了5个小时 还要学习软件、录入字体
- 白描网页版 - 高效准确且免费的OCR文字识别工具
- 字体图形面板与图标字体使用_字体图标的优势和劣势
- 作为前端工程师必须懂得的33个CSS核心概念
- Flutter程序员开发炫酷的登录页面 字体库运用 路由学习 源码分享
- 2025Q3开源字体盘点:让你的代码和文档'颜值'飙升!
- Agent杂谈:Agent的能力上下限及「Agent构建」核心技术栈调研分享~
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)