search
HomeWeb Front-endJS TutorialIntroduction to JavaScript Pattern Factory Pattern Application_Javascript Skills

Factory pattern is also one of the object creation patterns. It is usually implemented in a class or a static method of a class. One way to construct an object is to use the new operator, but using new is precisely for implementation programming, which will cause "coupling" problems and is closely related to the specific class. This makes the code more fragile and lacks flexibility. In projects with complex logic, it is recommended to interface-oriented programming.
Look at the simple factory pattern first

Copy the code The code is as follows:

Person(name, age) {
var obj = {}
obj.name = name
obj.age = age
return obj
}
var p1 = Person('jack', 25)
var p2 = Person('lily', 22)

The difference between writing a class in the constructor way is that you do not use this, but construct an empty object every time and then give it Add properties. The way to create an object is not to use new, but to use function calling. This approach is basically used to replace a class (objects with the same properties), while more complex factories can create different types of objects.
The following is an example of a fruit factory
Copy the code The code is as follows:

function Banana( ) {
this.price = '$1.5'
}
function Apple() {
this.price = '$1.2'
}
function Orange() {
this .price = '$2.2'
}
// Static factory class
function Fruit() {}
Fruit.factory = function(type) {
if (!window[type]) {
return
}
var fruit = new window[type]
return fruit
}
// Make different fruits
var banana = Fruit.factory('Banana ')
var apple = Fruit.factory('Apple')
var orange = Fruit.factory('Orange')

There are three fruit classes Banana, Apple, and Orange, one The fruit factory class Fruit can create different fruit objects each time through the static method factory.
The factory pattern is also reflected in the JavaScript native object Object, such as
Copy code The code is as follows:

var obj = Object(),
num = Object(1),
str = Object('s'),
boo = Object(false);

Object is a factory, which will construct different objects according to different parameters. obj is an empty object, num is a Number type object, str is a String type object, and boo is a Boolean type object.
jQuery.Callbacks is also a factory. Each time it is called, it will return an object with methods such as add, remove, fire, etc. Objects with different properties can also be constructed based on parameters such as "once", "memory", etc.

The so-called factory pattern refers to a method that can return an object.
What can we do using this model? Suppose I am not satisfied with the methods in the existing DOM objects and I want to add a custom method called sayHello. We can do this:
Copy code The code is as follows:

function RemouldNodeObj(DomNode){
//First determine whether the parameter passed in is a Dom node
if(typeof DomNode == "object" && DomNode.nodeType == 1){
DomNode.say = function(){
alert("Hello!!");
}
}else{
alert("The parameters you passed in are incorrect!");
}
}

//Call like this:
window.onload = function(){
var oDiv = RemouldNodeObj(document.getElementById("test"));
//With this step, oDiv has a new method say
oDiv.say();
}

After having the above foundation, let's implement some complex functions. We want to generate a simple form by calling js. Look at the code:
Copy the code The code is as follows:



JavaScript factory mode




###




Did you see it? Is this calling method very similar to jQuery? If we can solve the cross-browser problem, we can actually make a search bar plug-in!
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
微信的免打扰模式有什么作用微信的免打扰模式有什么作用Feb 23, 2024 pm 10:48 PM

微信勿扰模式什么意思如今,随着智能手机的普及和移动互联网的迅猛发展,社交媒体平台已经成为人们日常生活中不可或缺的一部分。而微信作为国内最流行的社交媒体平台之一,几乎每个人都有一个微信账号。我们可以通过微信与朋友、家人、同事进行实时沟通,分享生活中的点滴,了解彼此的近况。然而,在这个时代,我们也不可避免地面临着信息过载和隐私泄露的问题,特别是对于那些需要专注或

iPhone上的睡眠模式有何用途?iPhone上的睡眠模式有何用途?Nov 04, 2023 am 11:13 AM

长期以来,iOS设备一直能够使用“健康”应用程序跟踪您的睡眠模式等。但是,当您在睡觉时被通知打扰时,这不是很烦人吗?这些通知可能无关紧要,因此在此过程中会扰乱您的睡眠模式。虽然免打扰模式是避免睡觉时分心的好方法,但它可能会导致您错过夜间收到的重要电话和消息。值得庆幸的是,这就是睡眠模式的用武之地。让我们了解更多关于它以及如何在iPhone上使用它的信息。睡眠模式在iPhone上有什么作用睡眠模式是iOS中专用的专注模式,会根据你在“健康”App中的睡眠定时自动激活。它可以帮助您设置闹钟,然后可以

epc+o模式是什么意思epc+o模式是什么意思Nov 09, 2022 am 10:54 AM

epc+o模式就是指设计、采购等等为一体的总承包框架,它是在epc里面引申出来的一些运营环节;即在建设期内时,总承包商除了要去承担传统意义上的设计任务以外,还要去包揽在运营期内的所有维护任务。该模式可以极大程度提高许多项目的运营效率,也可以迅速降低运营成本。

在 Windows 10/11 上如何离开 S 模式在 Windows 10/11 上如何离开 S 模式Aug 03, 2023 pm 08:17 PM

S模式下的窗口旨在通过仅允许从Microsoft应用商店安装应用来提供增强的安全性和性能。虽然此功能有助于防止恶意软件和确保安全的计算环境,但它可能会限制想要从MicrosoftStore以外的源安装应用程序的用户。如果您发现自己处于这种情况并不断问自己如何在Windows10/11中切换出S模式,那么您来对地方了,因为我们将引导您完成如何使用两种不同的方法在Windows10/11中切换出S模式的步骤,确保您可以享受从您选择的任何地方安装应用程序的自由。了解如何在Windows中切换出S模式将

iPhone 15 Pro:如何摆脱状态栏中的静音模式符号iPhone 15 Pro:如何摆脱状态栏中的静音模式符号Sep 24, 2023 pm 10:01 PM

在iPhone15Pro和iPhone15ProMax型号上,Apple推出了一个物理可编程的动作按钮,取代了音量按钮上方的传统响铃/静音开关。可以对操作按钮进行编程以执行几种不同的功能,但是在静音和响铃模式之间切换的能力并没有消失。默认情况下,长按一次操作按钮将使设备静音,按钮的触觉反馈将发出三个脉冲。两款iPhone15Pro机型在状态栏中的时间旁边都会显示一个划掉的铃铛符号,表示静音/静音模式已激活,并且它将一直保持到您再次长按“操作”按钮取消设备静音。如果您倾向于将iPhone置于静音模

iOS 17中的待机模式使用指南iOS 17中的待机模式使用指南Aug 22, 2023 pm 04:01 PM

待机模式即将通过iOS17进入iPhone,本指南旨在向您展示如何在iPhone上使用此功能。待机模式是一项突破性功能,可将iPhone转变为动态、始终开启的智能显示屏。当您的iPhone在充电过程中水平侧放时,它会激活待机模式。此模式精美地展示了大量有用的小部件,包括但不限于当前时间、当地天气更新、您喜欢的照片的幻灯片,甚至是音乐播放控件。此模式的一个显着优点是它能够显示通知,允许用户查看和参与通知,而无需完全唤醒他们的iPhone。如何使用待机模式要使待机模式正常运行,iPhone必须运行i

如何启用“记事本++深色模式”和“记事本++深色主题”?如何启用“记事本++深色模式”和“记事本++深色主题”?Oct 27, 2023 pm 11:17 PM

记事本++暗模式v8.0没有参数,Notepad++是最有用的文本编辑器。在Windows10上运行的每个应用程序都支持暗模式。您可以命名Web浏览器,例如Chrome、Firefox和MicrosoftEdge。如果您在记事本++上工作,默认的白色背景可能会伤害您的眼睛。开发人员已将暗模式添加到版本8的Notepad++中,这是打开它的方法。为Windows11/10启用记事本++暗模式启动记事本++单击“设置”>“首选项”>“暗模式”选择“启用深色模式”重新启动记

我应该每次都关闭笔记本电脑吗?我应该每次都关闭笔记本电脑吗?Feb 19, 2024 pm 12:09 PM

Windows笔记本电脑带有休眠和关机选项。当您将笔记本电脑置于睡眠模式时,它将进入低功耗模式,您可以以任何离开它的方式继续工作。如果您关闭了笔记本电脑,则需要关闭所有程序以及您的工作并重新开始。如果你想在一天内从笔记本电脑上稍事休息,睡眠模式或休眠模式是不错的选择。那关门呢?我应该每次都关闭笔记本电脑吗?让我们来找出答案。我应该每次都关闭笔记本电脑吗?关闭笔记本电脑可能是个好主意,因为可以节省能源、延长设备寿命,特别是在长时间不使用时。但是在白天,将笔记本电脑置于睡眠模式以继续任务是个不错的选

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),