In tech, terms and acronyms are everywhere.
Sometimes when we hear them, they can seem vaguely familiar; or maybe we've used them extensively, read them somewhere, or heard it briefly during a conversation. But how many of them do we really know and understand?
Did you know them all before? If we missed something, send us a DM on twitter
Application Programming Interface. A set of subroutine definitions, communication protocols, and tools for building software. In general terms, it is a set of clearly defined methods of communication among various components. An API specification can take many forms, but often includes specifications for routines, data structures, object classes, variables, or remote calls. Documentation for the API usually is provided to facilitate usage and implementation.
Application program, is a software program that runs on your computer. Web browsers, email programs, word processors, games, and utilities are all applications. The word "application" is used because each program has a specific application for the user. In other words, it’sa software designed to perform a group of coordinated functions, tasks, or activities for the benefit of the user.
A closure is the combination of a function and the lexical environment within which that function was declared. A closure is a function that has access to the parent scope, even after the parent function has closed.
The Community Committee (CommComm) is a top-level committee in the Node.js Foundation. The CommComm has authority over outward-facing community outreach efforts, including community evangelism, education initiatives, the cultural direction of node.js foundation, community organization outreach, translation and internationalization, project moderation/mediation, public outreach and publications.
A computer program that translates computer code written in one programming language (the source language) into another language (the target language). The name “compiler” is primarily used for programs that translate source code from a high-level programming language to a lower level language (e.g., assembly language, object code, or machine code) to create an executable program.
Concurrency refers to the execution of multiple tasks over a period of time. When it comes to computers and processors, some tasks can be executed in parallel and some tasks have to be done one at a time. But generally speaking, concurrency happens in order-independent or partially-ordered units of work.
Alternately referred to as a processor, central processor, or microprocessor, the CPU is the central processing unit of the computer. A computer's CPU handles all instructions it receives from hardware and software running on the computer.
In Node.js, the dependencies’ value is used to specify any other modules that a given module (represented by the package.json) requires to work. You can install the dependencies with a package manager in your root folder, run
npm install or
yarn install and it will install any modules listed in that dependencies hash.
Encompasses all processes involved in getting new software or hardware up and running properly in its environment, this includes installation, configuration, running, testing, and making necessary changes.
A development environment is a collection of procedures and tools for developing, testing and debugging an application or program. The development environment normally has three server tiers, called development, staging and production. All three tiers together are usually referred to as the DSP.
A function is a block of organized, reusable code that is used to perform a single, related action. Functions provide better modularity for your application and a high degree of code reusing.
A software framework is a concrete or conceptual platform where common code with generic functionality can be selectively specialized or overridden by developers or users. Frameworks take the form of libraries, where a well-defined application program interface (API) is reusable anywhere within the software under development. Some examples of frameworks in Node.js include Express.js, Koa, Hapi, Nest, Restify and others.
A hostname is the label assigned to a device (a host) on a network and is used to distinguish one device from another on a specific network or over the internet.
The Hypertext Transfer Protocol (HTTP) is an application protocol for distributed, collaborative, hypermedia information systems. HTTP is the foundation of data communication for the World Wide Web, where hypertext documents include hyperlinks to other resources that the user can easily access, for example by a mouse click or by tapping the screen in a web browser.
Object, therefore it inherits all its properties and methods. In other words, any object that derives from another object is called an instance. In this way, all objects are instances of another one, except the Object class, that is the parent class.
with, and you cannot use these reserved words as variables, labels, or function names
Is a suite of data and programming code that is used to develop software programs and applications. It is designed to assist both the programmer and the programming language compiler in building and executing software.
A multi-platform support library that focuses on asynchronous I/O, primarily developed for use by Node.js.
(Don’t confuse it with TLS - as I do 😂) LTS is an acronym for Long-Term Support, and is applied to release lines that will be supported and maintained by the Node.js project for an extended period of time.
- Active: An Active LTS release line is one that is being actively maintained and upgraded, including backporting newer non-breaking features, functionality, and improvements, addressing bugs, and patching security vulnerabilities.
- Maintenance: A Maintenance LTS release line is a Node.js LTS release line that's nearing End of Life (EOL) and will only receive bug fixes and security patches for a short window of time.
Middleware functions are functions that have access to the request object (req), the response object (res), and the next function in the application’s request-response cycle. The next function is a function which, when invoked, executes the middleware succeeding the current middleware. Middleware functions can perform the following tasks:
- Execute any code.
- Make changes to the request and response objects.
- End the request-response cycle.
- Call the next middleware in the stack.
Is the world's largest Software Registry. The registry contains over 800,000 code packages, open-source developers use npm to share software and also, many organizations use npm to manage private development.
Node Version Manager is a tool that allows programmers to seamlessly switch between different versions of Node. You can install each version with a single command and set a default via the command-line
Open source software is software with source code that anyone can inspect, modify, and enhance. If a program is open-source, its source code is freely available to its users. Its users – and anyone else – have the ability to take this source code, modify it, and distribute their own versions of the program. The users also have the ability to distribute as many copies of the original program as preferred. Anyone can use the program for any purpose; there are no licensing fees or other restrictions on the software.
A package.json file lists the packages your project depends on, specifies versions of a package that your project can use using semantic versioning rule, and makes your build reproducible, and therefore easier to share with other developers.
Is a collection of software tools that automates the process of installing, upgrading, configuring, and removing computer programs for a computer's operating system in a consistent manner. A package manager deals with packages, distributions of software and data in archive files. Packages contain metadata, such as the software's name, description of its purpose, version number, vendor, and a list of dependencies necessary for the software to run properly. Upon installation, metadata is stored in a local package database. Package managers typically maintain a database of software dependencies and version information to prevent software mismatches and missing prerequisites.
Is a "logical connection place" and specifically, using the Internet's protocol, the way a client program specifies a particular server program on a computer in a network. Higher-level applications that use TCP/IP such as the Web protocol, Hypertext Transfer Protocol, have ports with preassigned numbers. Other application processes are given port numbers dynamically for each connection. When a service (server program) initially is started, it is said to bind to its designated port number. As any client program wants to use that server, it also must request to bind to the designated port number.
Is the instance of a computer program that is being executed by one or many threads. It contains the program code and its activity. Depending on the operating system, a process may be made up of multiple threads of execution that execute instructions concurrently.
The Promise object represents the eventual completion (or failure) of an asynchronous operation, and its resulting value.
A query is a request for data or information from a database table or combination of tables. This data may be generated as results returned by Structured Query Language (SQL) or as pictorials, graphs or complex results, e.g., trend analyses from data-mining tools. One of several different query languages may be used to perform a range of simple to complex database queries. SQL, the most well-known and widely-used query language, is familiar to most database administrators.
An HTTP request. A client submits an HTTP request message to a server, which returns a response. The request must use one of several request methods such as GET, POST, and so on.
An HTTP response. A server returns an HTTP response message to the client. The response contains completion status information about the request and might also contain requested content in its message body.
A read–eval–print loop (REPL), also termed an interactive top level or language shell, is a simple, interactive computer programming environment that takes single user inputs (i.e., single expressions), evaluates (executes) them, and returns the result to the user; a program written in a REPL environment is executed piecewise.
Refers to determining how an application responds to a client request to a particular endpoint, which is a URI (or path) and a specific HTTP request method (GET, POST, and so on). Each route can have one or more handler functions, which are executed when the route is matched.
Is a general term that refers to any library, framework, or platform that your code runs on. It describes software/instructions that are executed while your program is running, especially those instructions that you did not write explicitly, but are necessary for the proper execution of your code. Node.js is an open source, cross-platform runtime environment for developing server-side and networking applications.
Scope is the set of variables that’s visible to a part of the program.
Also known as standard error, is the default file descriptor where a process can write error messages. It’s an output stream typically used by programs to output error messages or diagnostics.
Also known as standard input, is stream data (often text) going into a program. The program requests data transfers by use of the read operation. It’s an input stream where data is sent to and read by a program.
Also known as standard output, is the stream where a program writes its output data. The program requests data transfer with the write operation. Not all programs generate output. For example, the file rename command (variously called mv, move, or ren) is silent on success.
Streams are collections of data — just like arrays or strings. The difference is that streams might not be available all at once, and they don’t have to fit in memory. This makes streams really powerful when working with large amounts of data, or data that’s coming from an external source one chunk at a time. However, streams are not only about working with big data. They also give us the power of composability in our code. Just like we can compose powerful linux commands by piping other smaller Linux commands, we can do exactly the same in Node with streams.
Transport Layer Security (TLS), and its now-deprecated predecessor, Secure Sockets Layer (SSL) are cryptographic protocols designed to provide communications security over a computer network. Several versions of the protocols find widespread use in applications such as web browsing, email, instant messaging, and voice over IP (VoIP). Websites can use TLS to secure all communications between their servers and web browsers.
TSC or Technical Steering Committee is the technical governing body of the Node.js Foundation and is responsible for the Node.js Core project, a number of projects depended upon by Node.js Core, and a number of projects adjacent to Node.js Core. The TSC exercises autonomy in managing its responsibilities and seeks agreement from the Node.js Foundation Board
The util module in Node.js is primarily designed to support the needs of Node.js' own internal APIs. However, many of the utilities are useful for application and module developers as well. It can be accessed using:
const util = require('util');.
const worker = require('worker_threads');.
XMLHttpRequest (XHR) objects to interact with servers. You can retrieve data from a URL without having to do a full page refresh. This enables a Web page to update just part of a page without disrupting what the user is doing.
XMLHttpRequest is used heavily in AJAX programming.
Fast, reliable, and secure dependency management. Yarn is a package manager for your code. It allows you to use and share code with other developers from around the world.
The zlib module in Node.js provides compression functionality implemented using Gzip and Deflate/Inflate. It can be accessed using:
const zlib = require('zlib');.
Compressing or decompressing a stream (such as a file) can be accomplished by piping the source stream data through a zlib stream into a destination stream.
One Last Thing...
If you want to keep up to date on the Node.js community and what's happening across the ecosystem, you should be sure to check out @NodeSource on Twitter. We try to spread the word as far and wide as possible about the awesome things that are always happening in the community.