


Wie werden „Pop-ups' entwickelt? Staatlich gesteuert oder zwingend erforderlich?
Dieser Artikel vermittelt Ihnen relevantes Wissen über Front-End-Entwicklungsfenster. Er stellt vor allem vor, wie Front-End-Entwicklungsingenieure schnell und effizient Pop-up-Fenster entwickeln können es wird dir hilfreich sein.
Als Frontend-Entwicklungsingenieur ist die Entwicklung verschiedener Popup-Fenster an der Tagesordnung, aber wie man das schnell, effizient und mit einem einheitlichen Stil macht, ist ein Problem.
Zustandsgesteuert
In den heutigen Front-End-Technologie-Stacks sind Vue
, React
, die Verwendung von zustandsgesteuerten ist eine gängige Methode. Wenn wir beispielsweise ein Popup-Fenster auf unserer Seite einführen möchten, klicken Sie auf eine Schaltfläche, um Folgendes anzuzeigen: Vue
、 React
的情况下,使用状态驱动是一种常用方式。比如我们页面要引入一个弹窗,点击某个按钮弹出:
<template> <div> <Modal1 v-show="visible" @close="closeModal" /> <button @click="showModal" >click</button> </div> </template> <script> import Modal1 from './modals/Modal1.vue' export default { components: { Modal1 }, data() { return { visible: false } }, methods: { // 弹出弹窗 showModal(){ this.visible = true }, // 关闭弹窗,并传回数据 closeModal(data) { this.visible = false // 拿到 data todo something } } }
以上有一个问题,控制弹窗显隐的变量、显示弹窗的逻辑、关闭弹窗的回调逻辑分散在不同的地方。
假设这个页面有不止一个弹窗,那么这样写:
<template> <div> <Modal1 v-show="visible1" @close="closeModal1" /> <Modal2 v-show="visible2" @close="closeModal2" /> <Modal3 v-show="visible3" @close="closeModal3" /> <button @click="showModal1" >click</button> <button @click="showModal2" >click</button> <button @click="showModal3" >click</button> </div> </template> <script> import Modal1 from './modals/Modal1.vue' import Modal2 from './modals/Modal2.vue' import Modal3 from './modals/Modal3.vue' export default { components: { Modal1, Modal2, Modal3 }, data() { return { visible1: false, visible2: false, visible3: false, } }, methods: { // 弹出弹窗 showModal1(){ this.visible1 = true }, // 关闭弹窗,并传回数据 closeModal1(data) { this.visible1 = false // 拿到 data todo something }, showModal2(){ this.visible2 = true }, // 关闭弹窗,并传回数据 closeModal2(data) { this.visible2 = false // 拿到 data todo something }, showModal3(){ this.visible3 = true }, // 关闭弹窗,并传回数据 closeModal3(data) { this.visible3 = false // 拿到 data todo something }, } }
这样写起来简直不要太啰嗦。
命令式开发(函数式)
我开发了 promise-modal 这个库,可以在 React 项目中 Promise 函数式的开发调用弹窗。
安装
npm i promise-modal
使用
你的 Modal 组件这样写,我们会传入 callbackResolve
和 callbackReject
import React, { useState } from 'react' import { Modal, Button } from 'antd' import PropTypes from 'prop-types' const TestModal = (props) => { const { title, callbackResolve, callbackReject } = props const [isModalVisible, setIsModalVisible] = useState(true) const handleOk = () => { setIsModalVisible(false) callbackResolve(true) } const handleCancel = () => { setIsModalVisible(false) callbackReject(false) } return ( <Modal destroyOnClose title={title} visible={isModalVisible} onOk={handleOk} onCancel={handleCancel}> <p>Some contents...</p> <p>Some contents...</p> </Modal> ) } TestModal.propTypes = { title: PropTypes.string.isRequired, callbackResolve: PropTypes.func.isRequired, callbackReject: PropTypes.func.isRequired, } export default TestModal
import { create } from 'promise-modal' import TestModal from './TestModal' // 如果你使用 Class 组件 export default (data) => create(TestModal, data) // 如果你使用函数式组件和 hooks,你必须创建一个自定义 hooks 返回 export const useTestModal = () => { const showTestModal = (data) => create(TestModal, data) return showTestModal }
Imperative Entwicklung (funktional)
Ich habe promise-modal Diese Bibliothek kann Promise in React-Projekten funktionsfähig machen. Entwickeln Sie das Anruf-Popup Fenster.
Installieren
import { useTestModal } from './modals/TestModal' const showTestModal = useTestModal() // use Promise.then showTestModal({ title: 'Test Modal', }) .then((response) => { console.log('response: ', response) }) .catch((error) => { console.log('error: ', error) }) // use await const res = await showTestModal({ title: 'Test Modal', }) console.log('res: ', res) // do something here
Verwenden
🎜Schreiben Sie Ihre modale Komponente so, wir übergebencallbackResolve
und callbackReject
zwei Requisiten für Ihre Komponente, Sie müssen sie beim Schließen des Modals aufrufen. 🎜rrreee🎜Übergeben Sie Ihre Modal-Komponente an die Erstellungsfunktion.🎜rrreee🎜Verwenden Sie Modal im Geschäftscode, genau wie die Promise-Funktion. 🎜rrreee🎜Natürlich war zwingende oder staatlich getriebene Entwicklung schon immer umstritten: 🎜🎜Das ist der Standpunkt von You Yuxi, der staatlich getriebene Entwicklung unterstützt: 🎜
Es gibt auch einige Internetnutzer, die den imperativen Stil unterstützen:
Abgefangene Schnipsel:
Für Benutzer Das Das heißt, er muss sich nur auf das konzentrieren, was er anzeigen möchte, und auf die Regeln für die Anzeige, und muss sich nicht besonders um irrelevante Logik wie das Ein- oder Ausblenden des Popup-Fensters kümmern – der Anruf selbst soll angezeigt werden.
Durch die Änderung in einen zwingenden Aufruf müssen Benutzer keine Komponenten einführen, keine Rückrufe deklarieren und den Logikfluss nicht unterbrechen. Sie können sich nur auf ihre eigenen Daten konzentrieren.
Meine Meinung
- Wenn der Staat mehrere Popup-Komponenten steuert, ist der Code zu redundant.
- Für große Teams haben Geschäftsentwickler an vorderster Front unterschiedliche Hierarchieebenen, unterschiedliche Codestile und dezentrale Statustreiber. Die Stile können nicht vereinheitlicht werden, was zu unordentlichem Code führt, der nicht verwaltet werden kann.
- Der funktionale Stil verspricht, dass Benutzer von Popup-Fenstern sich keine Gedanken über Logik wie Ein- und Ausblenden machen müssen. Das Prinzip der Nähe besteht darin, dass das entsprechende Popup-Fenster erst dann angezeigt wird, wenn das Unternehmen diesen Punkt erreicht Popup-Fensterfunktion aufgerufen wird.
- Natürlich erhöht diese Methode die Arbeit der Popup-Fenster-Entwickler, verringert jedoch die mentale Belastung der Popup-Fenster-Benutzer.
- Diese Bibliothek übergibt implizit
callbackResolve
和callbackReject
zwei Requisiten, und die Abhängigkeitsquelle ist unklar, was eine neue mentale Belastung mit sich bringt. Ich habe im Moment keine gute Idee, daher ist PR willkommen.
Abschließend
Würden Sie bei der Entwicklung von Popup-Fenstern lieber zustandsgesteuerte oder imperative Methoden verwenden? Ist Imperative für Ihr Team oder Projekt geeignet? Probieren Sie es aus.
Verwandte Tutorials: „Video-Tutorial zur Web-Front-End-Entwicklung“
Das obige ist der detaillierte Inhalt vonWie werden „Pop-ups' entwickelt? Staatlich gesteuert oder zwingend erforderlich?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



So implementieren Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem. Einführung: Mit der kontinuierlichen Weiterentwicklung der Technologie ist die Spracherkennungstechnologie zu einem wichtigen Bestandteil des Bereichs der künstlichen Intelligenz geworden. Das auf WebSocket und JavaScript basierende Online-Spracherkennungssystem zeichnet sich durch geringe Latenz, Echtzeit und plattformübergreifende Eigenschaften aus und hat sich zu einer weit verbreiteten Lösung entwickelt. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem implementieren.

WebSocket und JavaScript: Schlüsseltechnologien zur Realisierung von Echtzeit-Überwachungssystemen Einführung: Mit der rasanten Entwicklung der Internet-Technologie wurden Echtzeit-Überwachungssysteme in verschiedenen Bereichen weit verbreitet eingesetzt. Eine der Schlüsseltechnologien zur Erzielung einer Echtzeitüberwachung ist die Kombination von WebSocket und JavaScript. In diesem Artikel wird die Anwendung von WebSocket und JavaScript in Echtzeitüberwachungssystemen vorgestellt, Codebeispiele gegeben und deren Implementierungsprinzipien ausführlich erläutert. 1. WebSocket-Technologie

Einführung in die Verwendung von JavaScript und WebSocket zur Implementierung eines Online-Bestellsystems in Echtzeit: Mit der Popularität des Internets und dem Fortschritt der Technologie haben immer mehr Restaurants damit begonnen, Online-Bestelldienste anzubieten. Um ein Echtzeit-Online-Bestellsystem zu implementieren, können wir JavaScript und WebSocket-Technologie verwenden. WebSocket ist ein Vollduplex-Kommunikationsprotokoll, das auf dem TCP-Protokoll basiert und eine bidirektionale Kommunikation zwischen Client und Server in Echtzeit realisieren kann. Im Echtzeit-Online-Bestellsystem, wenn der Benutzer Gerichte auswählt und eine Bestellung aufgibt

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript. Im heutigen digitalen Zeitalter müssen immer mehr Unternehmen und Dienste Online-Reservierungsfunktionen bereitstellen. Es ist von entscheidender Bedeutung, ein effizientes Online-Reservierungssystem in Echtzeit zu implementieren. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Reservierungssystem implementieren, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist WebSocket? WebSocket ist eine Vollduplex-Methode für eine einzelne TCP-Verbindung.

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Einführung: Heutzutage ist die Genauigkeit von Wettervorhersagen für das tägliche Leben und die Entscheidungsfindung von großer Bedeutung. Mit der Weiterentwicklung der Technologie können wir genauere und zuverlässigere Wettervorhersagen liefern, indem wir Wetterdaten in Echtzeit erhalten. In diesem Artikel erfahren Sie, wie Sie mit JavaScript und WebSocket-Technologie ein effizientes Echtzeit-Wettervorhersagesystem aufbauen. In diesem Artikel wird der Implementierungsprozess anhand spezifischer Codebeispiele demonstriert. Wir

Verwendung: In JavaScript wird die Methode insertBefore() verwendet, um einen neuen Knoten in den DOM-Baum einzufügen. Diese Methode erfordert zwei Parameter: den neuen Knoten, der eingefügt werden soll, und den Referenzknoten (d. h. den Knoten, an dem der neue Knoten eingefügt wird).

JavaScript-Tutorial: So erhalten Sie HTTP-Statuscode. Es sind spezifische Codebeispiele erforderlich. Vorwort: Bei der Webentwicklung ist häufig die Dateninteraktion mit dem Server erforderlich. Bei der Kommunikation mit dem Server müssen wir häufig den zurückgegebenen HTTP-Statuscode abrufen, um festzustellen, ob der Vorgang erfolgreich ist, und die entsprechende Verarbeitung basierend auf verschiedenen Statuscodes durchführen. In diesem Artikel erfahren Sie, wie Sie mit JavaScript HTTP-Statuscodes abrufen und einige praktische Codebeispiele bereitstellen. Verwenden von XMLHttpRequest

Einführung in die Methode zum Abrufen des HTTP-Statuscodes in JavaScript: Bei der Front-End-Entwicklung müssen wir uns häufig mit der Interaktion mit der Back-End-Schnittstelle befassen, und der HTTP-Statuscode ist ein sehr wichtiger Teil davon. Das Verstehen und Abrufen von HTTP-Statuscodes hilft uns, die von der Schnittstelle zurückgegebenen Daten besser zu verarbeiten. In diesem Artikel wird erläutert, wie Sie mithilfe von JavaScript HTTP-Statuscodes erhalten, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist ein HTTP-Statuscode? HTTP-Statuscode bedeutet, dass der Dienst den Dienst anfordert, wenn er eine Anfrage an den Server initiiert
