Skip to main content

AUTOMATING KEYBOARD INPUT USING PUPPETEER AND NODE JS

AUTOMATING KEYBOARD INPUT USING PUPPETEER AND NODE JS
Hey there, welcome once again to another tutorial on trycoder.com where we gonna be talking about Google puppeteer and Node JS. If this is your first time visiting us, I recommend you subscribe to our YouTube channel and stick till the end. If it’s equally your first time reading about Google puppeteer, I recommend you check our introductory article about this and our YouTube video on this.

As you already know, puppeteer is headless chrome which can automate everything a user does with a browser.

Today, we will discuss how to automate keyboard input which could perhaps be in a form field, email or anywhere else.

Puppeteer has a keyboard class which has some methods responsible for keyboard events such as key down, press, type and more.
In the example below, we will examine and how these methods work.

Just as a user would normally do;

  • open a browser,
  • new tab/page
  • open url 
  • and then type something and
  • close browser when done

Let us discuss the following methods of the keyboard class;

keyboard.type(text,[Options])

This method types-in or inputs the text passed as parameter in a field selector (For example; “hello world”). Options can equally be passed to modify it’s operation.

keyboard.down(key,[Options])

As the name implies, this method handles only the key-down event. Which takes as param the key to be pressed down and options. For example, KeyC

keyboard.press(key,[Options])

This method handles both the key-down and key-up event to form a complete key-press.

keyboard.up(key)

As the name implies, this method handles only the key-up event. Which takes as param the key to be release-up and options. 

Now, let’s see how they work in code;

server.js

const puppeteer = require('puppeteer');
(async () => {
const browser = await puppeteer.launch() //launch headless browser
const page = await browser.newPage() //new page/tab
await page.goto('https://www.rapidtables.com/tools/notepad.html') //web link
await page.focus('textarea') //focus on selector which is the text area field
await page.keyboard.type('Hello World');
await page.keyboard.press('Enter');
await page.keyboard.type('Welcome to Google Puppeteer');
await page.keyboard.press('Enter');
await page.keyboard.type('Feel the magic ✨🎁');
await page.screenshot({ path: './uploads/image.png' });
await browser.close() //close browser
console.log ('done')
})()

The above code simply opens notepad on the web and then types in some text using the methods explained above.

OUTPUT

Run script:

AUTOMATING KEYBOARD INPUT USING PUPPETEER AND NODE JS

Check uploads folder

AUTOMATING KEYBOARD INPUT USING PUPPETEER AND NODE JS

To read more about the keyboard class of the puppeteer library, you can check out their official doc at : https://pptr.dev/

Thanks for coding with us.


Comments

Popular posts from this blog

JavaScript Functions

  Hi there, and welcome to another exciting lesson on JavaScript. If this is your first time here, please do well to check out our previous lessons. In the previous lesson, we were discussing JavaScript math methods. It was very intuitive as we got to learn how to use the various math methods. To proceed, we shall be looking at JavaScript functions.  A function in JavaScript like in every other programming language could be defined as a block of code that is written to perform a particular task, and this function is usually invoked or called before it is being implemented. We have been talking about methods throughout the previous lessons right. Do you know that those methods are actually functions? Yes they are functions. You can now have an overview of the importance of functions in every programming language. How do we create a function in JS? To create a function, you follow the format function functionName(Argument) {//Block of code }. Some functions do have a return val...

JavaScript Math Methods

Hello everyone, and welcome to another exciting JavaScript lesson. In the last lessons you have been seeing other methods being used in JS (for example, the string methods). We shall go further into exploring other methods. This time, it’s going to be math methods. Do not move an inch because it’s going to be a very exciting. Before we look at what a math method is, let’s have an overview of math objects. A math object in JavaScript is a static built-in object that includes properties and methods used in performing mathematical tasks. Talking about math properties, they have the syntax Math.property . Some examples are Math.E that returns Euler’s number, Math.PI that returns PI, Math.LN2 that returns the natural logarithm of 2, and many others. The various JavaScript methods contained in the math object, thus, make mathematical operations easier and reduce effort as well as time in math-oriented programming. Some JS methods include abs( ), ceil( ), cos( ), sqrt( ), pow( ), log( ) ...

How to generate random numbers using NumP1

Hello. Welcome to another edition on this platform. For more better understanding, do checkout our YouTube channel to get the video tutorial. In this article of today, we are going to see how to generate random numbers using any of the following methods: Generating a random number Generating a random float and integer Generating random number arrays Generating random number from an array What is a random number? This is a number which cannot be predicted before its occurrence. This number might not different every time. Programmatically, they are two categories of random numbers:     Pseudo-Random numbers       True Random numbers. Just as programs which are written by programmers are a set of instructions, we must follow an algorithm to generate random numbers. Random numbers which are generated using an algorithm are called Pseudo-Random numbers. To generate a true random number, it is important to get the data from sources such as the keyboards, mou...