I. Project Introduction:
This document introduces the development process and review of Wokoo plugin scaffolding. Wokoo is the scaffolding I developed to quickly start a foundation project for the oilmonkey plugin development.
- Wokoo NPM address: Wokoo
- Wokoo github address: Wokoo (if you like it, please click the little star)
- Wokoo scaffolding development of oil monkey plug-in are:
- Zhihu directory
- Cross word search
- Install the oil monkey plugin before using these two plugins. If you don’t have a ladder, install ➡️ oil monkey plugin from here
- Wokoo User Guide 👉 5 minutes to get started with the development of a browser plug-in – Oil monkey scaffolding Wokoo (User guide)
- Don’t know what an oilmonkey plugin is? Tampermonkey: Tampermonkey: Tampermonkey: Tampermonkey: Tampermonkey: Tampermonkey
In this project, I played the roles of product manager, developer R and operation officer of the project. Being responsible for developing an open source project from start to finish gives me a great sense of accomplishment.
Back to the original intention to do Wokoo scaffolding, just because they want to write an oil monkey plug-in, found more trouble, they also wade in some pits. I just thought it would make sense to write a scaffolding, one-click base oil Monkey project. After I finished Wokoo scaffolding, I shared this article in a tech group and was invited to do a share by the big guys in the group. So I added the case of using Wokoo for real projects. Then guide the members of the group to complete from scratch, to achieve the development of an oil monkey plug-in.
The whole process was just a small idea at the beginning, but in the process of gradually upgrading the monster fighting, I turned the original small idea into a formal open source project. This experience has given me a lot of growth, including technology, communication, cooperation and so on. Thanks for the experience ~ 🎉
Ii. Project Background
Wokoo scaffolding was developed originally
At first I wanted to make a browser plug-in for internal team use. During the selection of technology, it is found that the development of oil monkey plug-in is the most time-saving and labor-saving, and it is the best choice without review and on-line fast.
The development process encountered some potholes:
-
The Oilmonkey plugin is essentially embedding a piece of JS code into the current HTML. As a result, many oilmonkey plugins are developed directly using jQuery. This is not suitable for rd, which is used to Vue, React and other frameworks, especially when plug-ins involve page component development, using jQuery is a bit of a pain. This is the first pain point: configuring the VUE or React base project
-
So I considered using VUE-CLI to create a VUE project to complete plug-in development. Once the project was created, I found myself configuring the Oil Monkey script. For example, @match specifies that the plugin should be enabled under certain domain names. // @match http://*/* indicates that the plugin can only be used in HTTP web pages. The default configuration is HTTP, but now web pages are upgraded to HTTPS, if you do not change this configuration, you will find that the plugin will not work. 👇
Second pain point: Read the documentation of the Oil Monkey script and understand the comments
- Projects developed using VUE can pass
localhost:8080
Access, but how do you combine your project with the Oilmonkey plug-in so that you can debug the plug-in in real time while developing the project? You can’t develop at the same timenpm run build
Build the package and copy the build results into the Editor of the Oilmonkey plugin.Third pain point: how to show the effects of plug-ins while developing?
The business scenario
To sum up, I would like to implement a scaffolding for the development of the Oil monkey plugin, which meets the following functions:
- Enter a command line to generate a base project
- The basic oil Monkey script configuration is included in the project
- Provide solutions, so that the oil monkey plug-in can be side development, side debugging
Pain points of resolution
Wokoo scaffolding is designed to meet the business scenario and solve three pain points I encountered when developing the Oilmonkey plugin.
-
One click to create the basic Oil Monkey plug-in project, optional templates are:
[ ] vue
[ ] react
-
The tamperMonkey.js file in the base project satisfies the basic configuration of the Oilmonkey plug-in, for example:
// ==UserScript== // @name my-plugin // @namespace http://tampermonkey.net/ / / @ version 0.0.1 // @description try to take over the world! // @author // @match https://*/* // @match http://*/* // ==/UserScript==; (function () { 'use strict' if (location.href === 'http://localhost:8080/') return var script = document.createElement('script') script.src = 'http://localhost:8080/app.bundle.js' document.body.appendChild(script) })() Copy the code
Developers can simply copy this code into the Oilmonkey plugin editor to solve the second pain point above.
Wokoo scaffolding provides basic documentation to ease the development of the Monkey plugin.
-
Tampermonkey.js js script, the oil monkey plug-in loaded JS file into the local service with Webpack, to achieve development while debugging. Address the third pain point above.
Iii. Practice Process:
Technology selection
- Refer to thecreate-react-appThe design idea will be
wokoo-scripts
andwokoo-template
Part is decoupled and divided into two packages for separate management, which is conducive to future function expansion. For example, if you want to add a new template based on jquery in the future, you just need to expand the Wokoo-Template section. - Monorepo scheme manages code, using Lerna for package management.
The development process
This is an architectural design for Wokoo. Wokoo uses monorepo to manage code and maintains two modules, Wokoo-scripts and Wokoo-Template, in a Git repository. Use LerNA for package management.
Train of thought to sort out
The functions I want to implement are as follows:
-
To install wokoo, run NPM I wokoo -g to install wokoo in the global directory of NPM
-
Run the wokoo my-app command, and a message is displayed asking you to select a template
? which template do you prefer? (Use arrow keys) ❯ vue react Copy the code
-
After selecting the template, create a base project, including: 1. The configured Vue or React project, 2. Tampermonk. js file, and the configured base Oilmonkey script.
Mimicking crA, I split Wokoo into two parts, Wokoo-scripts and Wokoo-Template.
wokoo-scripts
Responsible for command line interaction, pull from NPMwokoo-template
Into the generated base project my-app.wokoo-template
Two sets of templates are provided, the lightweight configuration of vue and the React base project. Also providetampermonkey.js
file
The work of the entire project flows into 👇 :
wokoo-scripts
Catalog Introduction:
. ├ ─ ─ the README. Md ├ ─ ─ bin │ └ ─ ─ the WWW for NPM entry documents ├ ─ ─ index, js, the main program, ├─ package-lock.json ├─ package.json ├─ ├─ download.jsonCopy the code
Code flow chart:
Wokoo -scripts: init -> createApp -> Run ->modifyTemplate And the functions realized by each method.
wokoo-template
Catalog Introduction:
. ├ ─ ─ the README. Md ├ ─ ─ package - lock. Json ├ ─ ─ package. The json ├ ─ ─ public │ ├ ─ ─ the favicon. Ico │ ├ ─ ─ icon. JPG │ └ ─ ─ index. The HTML HTML file ├ ─ ─ the react - template react template path │ ├ ─ ─ the README. Md │ ├ ─ ─ the SRC │ │ ├ ─ ─ app. Js │ │ ├ ─ ─ app. Less │ │ └ ─ ─ index. The js │ entry documents ├── ├─ template.json ├─ ├─ webpack.config.base.js For The React project Webpack ├── │ ├─ React/Vue template └─ webpack.config.js Public Webpack configurationCopy the code
Wokoo-template provides a template for the base project:
-
There are vue-template and react-template
-
Vue-template and React-template correspond to a vUE or React base project configured for WebPack, respectively
-
Wokoo -scripts injection variables using EJS templates
-
The tampermonk. js file is the configuration file for the Oilmonkey plug-in, and you need to copy the code in this file into the oilmonkey plug-in edit box. Here is the contents of the tampermonkey.js file:
// ==UserScript== // @name <%=projectName%> // @namespace http://tampermonkey.net/ // @version <%=version%> // @description try to take over the world! // @author // @match https://*/* // @match http://*/* // ==/UserScript==; (function () { 'use strict' if (location.href === 'http://localhost:8080/') return var script = document.createElement('script') script.src = 'http://localhost:8080/app.bundle.js' document.body.appendChild(script) })() Copy the code
The annotated //@xxx in this file has meaning and can be understood in the TamperMonkey development documentation.
-
@name The name of the script, which will eventually be replaced with the project name
-
@namespace can write its own domain name, when you share the script, users can directly find your specific function through here
-
@description Plug-in description
-
@match Specifies whether to enable the plug-in under certain domain names. Two plug-ins are configured by default. // @match https://*/* and // @match https://*/* indicate that the plug-in is enabled under all domain names.
For details of the development process, read the article wokoo Scaffolding.
Results show
-
Creating the base project
npx wokoo my-app Copy the code
-
The service
npm start Copy the code
-
Copy the tampermonkey.js content into the Oilmonkey plugin editor. Note: Copy the entire content, including the comments. (This step by default you have installed the oil monkey plug-in, if not, install 👉 oil monkey plug-in installation address)
- Open a web page, you can see a monkey 🐒, on behalf of the process has run, you only need to develop their own business code.
Problems and solutions encountered during development
Question 1
The essence of the oil monkey plugin is to inject a javascript script into the page, and take care to avoid conflicts with the original page. Take Zhihu for example.
- The root node ID of the project created using wokoo scaffolding =root, and there is already a div node id=root in the root node page of Zhihu, so the name is repeated.
- Not only should the name of the root node ID be careful not to duplicate elements in the host web page, but wokoo should also create different root node ids for project A and project B. Since users may use multiple plugins at the same time, such as “dash search” and “Zhihu directory”, it is important to ensure that the root node ID of the two plugins is different.
The solution
Name the root node in wokoo-template according to wokooApp-${project name}-${timestamp} to avoid collisions.
Question 2
Some web security policies are better. For example, Zhihu uses CSP content security policy to prevent loading js scripts with non-specified domain names.
Considering the actual situation, for example, we have used Wokoo to initialize a project my-App and completed the configuration of the oil monkey script. When we opened Zhihu, we found that the monkey logo did not appear in the upper right corner and the console reported an error.
If you look at the response header for the requested HTML resource, you can see that there is an additional content-security-policy rule. In other words, Zhihu uses the CSP content security policy. According to the script-src field in Content-Security-Policy, Zhihu only allows js of the specified domain name to be loaded. For details, see 👉 Content Security Policy (CSP).
To copy the tampermonk. js file to the Oilmonkey plugin editor, you have the following code: 👇
// ==/UserScript==; (function () {
'use strict'
if (location.href === 'http://localhost:8080/') return
var script = document.createElement('script')
script.src = 'http://localhost:8080/app.bundle.js'
document.body.appendChild(script)
})()
Copy the code
Because we are debugging to ensure real-time view plug-in effect, when the page HTML spell a js file, and the file pointing webpack up service: http://localhost:8080/app.bundle.js. This is not the designated domain name of Zhihu, of course it was blocked.
The solution
What to do? Hey hey, wokoo scaffolding gives a solution of course.
-
During the development phase, the plugin Disable Content-security-policy is installed. When the plugin is enabled during the debugging of Zhihu page, the content-security-policy of THE HTML page is automatically set to empty.
-
When going online to the Oilmonkey market, copy the constructed script to the oilmonkey plug-in editor, avoiding deployment by CDN.
-
Note that the edit box has a maximum limit on code. If the size of app.bundle.js exceeds this limit, it will be unpacked.
Unpacking steps:
-
Add two lines of configuration code in the Oilmonkey editor. Here I use React as an example to introduce React as a static resource link
// @require https://unpkg.com/react@17/umd/react.production.min.js // @require https://unpkg.com/react-dom@17/umd/react-dom.production.min.js Copy the code
-
Modify the entry field of webpack.config.base.js
Entry: {app: '/ SRC /index.js', vendor: [// Pack react and react-dom separately to reduce the size of the package file 'react', 'react-dom',],}Copy the code
-
Rebuild the code and copy it into the edit box.
-
I have written a special document on how to use Wokoo:
5 minutes to develop a browser plugin – Oil Monkey Scaffolding Wokoo
Quick development of oil Monkey plug-in
Iv. Summary thinking:
Technical gain
- In order to write a professional scaffolding, I went to study the source code of create-React-app. I really admire the code written by the big guy. In the future, I should also consider the organizational structure and logical decoupling when writing the code.
- With monorepo, a single Git repository manages multiple library files (including wokoo-script and Wokoo-template). Find true fragrance 👍. It solves the problem of switching the warehouse and code of different libraries when developing multiple related libraries, and ensures the continuity of workflow.
In short, in the road to technology or a word: “paper come zhongjue shallow, must know this to practice”.
Mental gain
-
I realized that when I do something, whether it is a share, an article, or an open source project or a product, the most fundamental starting point should be “better users of service products”. You can only get the most value out of what you do if you serve your users well.
For example, when I shared in the group that I was developing the plugin “scratch word search” with Wokoo scaffolding, I found that people always asked me some simple questions. At that time, I thought it was clearly written in the document. Later, when I read that content again, I found that I was writing the document from the perspective of the developer, rather than from the perspective of the user.
-
Anything may seem difficult at first, but when you break it down into small things it won’t seem so difficult. Like Wokoo scaffolding, it is broken down into multiple steps:
- Development scaffolding
- Write and use documentation
- Write the actual case of the oil monkey plug-in
So when you encounter something, break it down into a few small steps to complete. Don’t let a big project scare you into thinking you can’t handle it.
Five, previous articles
Besides the oilmonkey scaffolding Wokoo, I also built other wheels 🎉🎉 :
-
Shero-cli: Automates the management of Github blogs
-
Tapable visualization tool
Welcome everyone on the road to make technology to upgrade the wheel
–
Thank you for reading 😊 and I hope you found this article helpful.
This article is participating in the “Nuggets 2021 Spring Recruitment Campaign”, click to see the details of the campaign