Snippets

Conditionally add properties๐Ÿ’ก in the object from 11 Useful Modern JavaScript Tips

const isValid = false
const age = 18

const person = {
  name: "Krina",
  ...(isValid && { isActive: true }),
  ...(age >= 18 || (isValid && { card: 0 })),
}

58 JavaScript Tips and Tricks for Web Developers

Loop array

const array = ["a", "b", "c"]

for (let item of array) {
  console.log(item)
}

Copy text to clipboard

const copyTextarea = document.querySelector("#urlToShare")
copyTextarea.focus()
copyTextarea.select()

try {
  document.execCommand("copy")
  alert(this.$t("URL์ด ๋ณต์‚ฌ๋˜์—ˆ์Šต๋‹ˆ๋‹ค. ์›ํ•˜๋Š” ๊ณณ์— ๋ถ™์—ฌ๋„ฃ๊ธฐ ํ•˜์„ธ์š”."))
} catch (err) {
  alert(this.$t("๋ณต์‚ฌ๊ฐ€ ์‹คํŒจํ–ˆ์Šต๋‹ˆ๋‹ค. ์ง์ ‘ ๋ณต์‚ฌํ•˜์„ธ์š”."))
}

Throttling requests

let cRequest = 0

export const preventDOSsuspiciousAction = () => {
  cRequest++
  return new Promise((resolve) => {
    setTimeout(() => {
      cRequest = 0
      resolve()
    }, cRequest * 300)
  })
}
//
window.promisePost = async (URL, prms, noToast = false, loadingFor) => {
  showBusyIndicator(loadingFor)
  await preventDOSsuspiciousAction()

  return new Promise((resolve, reject) => {
    $.post(URL, prms)
      .done((rsp) => {
        if (rsp.success) {
          resolve(rsp)
          return
        }
        if (!noToast) vueObj.$toast.open(rsp.message)
        reject(rsp)
      })
      .fail(reject)
      .always(() => {
        hideBusyIndicator(loadingFor)
      })
  })
}

Deep copy in JavaScript

const original = { id: 0, prop: { name: "Tom" } }
/* Old hack */
const deepCopy = JSON.parse(JSON.stringify(original))
/* New way */
const deepCopy = structuredClone(original)

Children
  1. Dynamic Include JavaScript, Style