JavaScript手寫源碼之omit函數(shù)的實現(xiàn)
最近突然有個新的想法,想去看看前端的小庫來提升自己的編碼能力。但是又不知道怎么去證明自己是否真的看懂了,那就實現(xiàn)一個mini的吧。
添加測試文件
我們通過vitest來實現(xiàn)測試的功能。
pnpm add -D vitest
然后再package.json
文件中添加我們的執(zhí)行腳本
"scripts": { "test": "vitest" }
接著我們就可以編寫測試文件了
import { describe, expect, test } from "vitest" import { myOmit } from "." describe("omit", () => { test("should create a shallow copy", () => { const mick = { name: "mick" } const copy = myOmit(mick, []) expect(copy).toEqual({ name: "mick" }) }) test("should drop fields which are passed in ", () => { const mick = { name: "mick", age: 18 } const copy = myOmit(mick, ["age"]) expect(copy).toEqual({ name: "mick" }) expect(mick).toEqual({ name: "mick", age: 18 }) expect(myOmit(mick, ["name", "age"])).toEqual({}) }) })
實現(xiàn)omit函數(shù)
我們要做的肯定是是要將測試文件通過。如果測試通過了,那就說明我們的功能基本上是已經(jīng)實現(xiàn)了,剩下的是代碼重構(gòu)了。
根據(jù)測試文件我們可以看到,提出對象中的屬性生成一個新的對象,但是原對象是不發(fā)生改變的。那可以用Object.assign
,下面介紹一個Object.assign
Object.assign()
方法將所有可枚舉(Object.propertyIsEnumerable()
返回 true
)和自有(Object.hasOwnProperty()
返回 true
)屬性從一個或多個源對象復制到目標對象,返回修改后的對象。
我們首先利用Object.assign
將原對象復制一份,然后遍歷復制過后的對象將需要剔除的屬性刪除即可。
export function myOmit(value, args) { const shallowCopy = Object.assign({}, value) for (let i = 0; i < args.length; i++) { const key = args[i] if (key in shallowCopy) { delete shallowCopy[key] } } return shallowCopy }
執(zhí)行測試文件
到此這篇關(guān)于JavaScript手寫源碼之omit函數(shù)的實現(xiàn)的文章就介紹到這了,更多相關(guān)JavaScript omit函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
老生常談document.ready和window.onload
這篇文章主要介紹了document.ready和window.onload的相關(guān)知識,包括document.ready和window.onload的區(qū)別,要使用document.ready()或者document.onload()的原因分析,本文結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2024-01-01網(wǎng)頁中可關(guān)閉的漂浮窗口實現(xiàn)可自行調(diào)節(jié)
廣告式的漂浮窗口,想必大家并不陌生吧,下面為大家簡單介紹下具體的實現(xiàn),有需要的朋友可以參考下2013-08-08JavaScript判斷變量名是否存在數(shù)組中的實例
下面小編就為大家分享一篇JavaScript判斷變量名是否存在數(shù)組中的實例,具有很的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12- 什么是函數(shù)式編程?根據(jù)百度百科的描述,“函數(shù)式編程是種編程典范,它將電腦運算視為函數(shù)的計算。函數(shù)編程語言最重要的基礎是 λ 演算(lambda calculus)。而且λ演算的函數(shù)可以接受函數(shù)當作輸入(參數(shù))和輸出(返回值)?!?/div> 2015-10-10
最新評論