Miré el código de muestra para conectar mongodb y vi una oración que no entendí.
¿Por qué es seguro usar variables globales en el caso del desarrollo? ¿Y por qué no está en producción?
No es necesario que entiendas el código. Por favor vea solo la sección de comentarios.
import { MongoClient } from 'mongodb' let client let clientPromise if (process.env.NODE_ENV === 'development') { // In development mode, use a global variable so that the value // is preserved across module reloads caused by HMR (Hot Module Replacement). if (!global._mongoClientPromise) { client = new MongoClient(uri, options) global._mongoClientPromise = client.connect() } clientPromise = global._mongoClientPromise } else { // In production mode, it's best to not use a global variable. client = new MongoClient(uri, options) clientPromise = client.connect() } // Export a module-scoped MongoClient promise. By doing this in a // separate module, the client can be shared across functions. export default clientPromise
Si se tratara solo de código de buena calidad, sería mejor no usar variables globales en el entorno de desarrollo también.
No estoy seguro de qué tiene de malo escribir en una variable global En entorno de producción.
Tiene que ver con el uso de "Reemplazo de módulo activo" en desarrollo para mejorar la productividad de desarrollo. No es algo que harías en un entorno de producción.
En el reemplazo de módulos en caliente, las variables de nivel de módulo como client
y clientPromise
se reemplazarían cuando el módulo se "reemplazara en caliente", pero se conservarían las variables globales.
Es un "truco" de desarrollo, no algo que hacer en producción.
Personalmente, ni siquiera lo haría en desarrollo porque prefiero ejecutar un código que esté lo más cerca posible de la producción cuando esté en desarrollo, excepto por cosas que deben ser diferentes.