0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

淺析單測(cè)在商家前端業(yè)務(wù)中的實(shí)踐

OSC開(kāi)源社區(qū) ? 來(lái)源:得物技術(shù) ? 2023-01-12 10:28 ? 次閱讀

1

背景

商家系統(tǒng)是提供給得物商家在得物平臺(tái)上可以穩(wěn)定運(yùn)營(yíng)的服務(wù)抓手,前端代碼也伴隨著系統(tǒng)的發(fā)展而不斷壯大。這樣將導(dǎo)致文檔卻更新不及時(shí),最后想再通過(guò)這些文檔回溯業(yè)務(wù)邏輯也非常困難。

且若代碼結(jié)構(gòu)上沒(méi)有關(guān)注,動(dòng)輒就會(huì)產(chǎn)出一個(gè)大幾千行的文件,人員交替維護(hù)的時(shí)候很難理清里面的邏輯,維護(hù)非常困難。

2

前端單測(cè)的難點(diǎn)

為解決上述痛點(diǎn),早在單測(cè)之前,團(tuán)隊(duì)上已經(jīng)做了一些其他事情來(lái)使文檔更清晰、代碼質(zhì)量更高,如寫(xiě)需求系分文檔、通過(guò)整潔架構(gòu)(The clean architecture)對(duì)代碼進(jìn)行分層、code review等等。但這些其實(shí)都只是外在的約束,只有內(nèi)在的代碼能真正經(jīng)得住單測(cè)的推敲,才能更好的保障我們的代碼質(zhì)量。

但目前現(xiàn)狀是前端大部分情況下都沒(méi)有接觸到單測(cè),僅在組件庫(kù)或工具類(lèi)的項(xiàng)目里有一些。這并不代表業(yè)務(wù)項(xiàng)目中前端就無(wú)法單測(cè), 而是因?yàn)橐恍┛陀^原因,導(dǎo)致前端在單測(cè)上的投入相對(duì)較少。

前端開(kāi)發(fā)的內(nèi)容比較雜,一個(gè)需求不僅僅是功能函數(shù)的編寫(xiě),還有UI的展示、dom交互的綁定等等,且若想單測(cè)完全覆蓋,將包含非常多的內(nèi)容,對(duì)業(yè)務(wù)前端來(lái)說(shuō)成本太高。

前端UI框架層出不窮,在業(yè)務(wù)開(kāi)發(fā)的時(shí)候,依賴(lài)框架也很容易將代碼邏輯和UI等完全耦合在一起,導(dǎo)致一個(gè)文件上千行,很難對(duì)這種代碼找到單測(cè)的切入點(diǎn)。

單測(cè)上手本身就有一定的門(mén)檻,要寫(xiě)出可維護(hù)性高的單測(cè)更不簡(jiǎn)單,會(huì)讓不熟悉的人望而卻步。

3

單測(cè)即文檔

鑒于上面的第一個(gè)難點(diǎn),前端涉及的內(nèi)容太雜,我們肯定無(wú)法給所有的代碼覆蓋單測(cè),去測(cè)到代碼的各個(gè)角落。再結(jié)合上我們自己本身的痛點(diǎn)(文檔更新不及時(shí),人員輪轉(zhuǎn)成本高),因此以“單測(cè)即文檔”為目標(biāo),我們只用覆蓋業(yè)務(wù)邏輯上的單測(cè)即可,只關(guān)注業(yè)務(wù)流程的銜接,通過(guò)用例將業(yè)務(wù)流程講清楚,對(duì)于單測(cè)的分支覆蓋率也不做強(qiáng)硬的要求。

Use Cases

因此,要在團(tuán)隊(duì)落地單測(cè)的第一步即是識(shí)別出實(shí)現(xiàn)業(yè)務(wù)邏輯的代碼模塊。若在較早的時(shí)候,想找到這個(gè)切入點(diǎn)可能還真沒(méi)有什么好的方法,因?yàn)槿菐浊械拇笪募疫壿嫼蚒I都耦合在一起。 正如前面所說(shuō),在單測(cè)推行前,我們已經(jīng)做了一些代碼準(zhǔn)備工作。得益于“整潔架構(gòu)”的推行,在開(kāi)發(fā)需求的同時(shí),已逐漸在對(duì)代碼進(jìn)行解耦重構(gòu),其核心就是依據(jù)各部分代碼作用的不同將其拆分成不同的層次,在各層次間制定了明確的依賴(lài)原則,達(dá)到與框架無(wú)關(guān)、與外部服務(wù)無(wú)關(guān)、并可測(cè)試的目的。

78a80d70-85ec-11ed-bfe3-dac502259ad0.png

經(jīng)過(guò)分層后,我們將業(yè)務(wù)邏輯主要都落在了usecase這一層,在我們的代碼結(jié)構(gòu)上,它的作用是將業(yè)務(wù)流程串聯(lián)起來(lái),且它僅依賴(lài)entities(主要對(duì)服務(wù)端返回?cái)?shù)據(jù)做適配和檢查)層,邏輯獨(dú)立不會(huì)因?yàn)橐蕾?lài)框架或UI的變化而無(wú)法運(yùn)行。

相較于后端服務(wù),前端應(yīng)用通常并不會(huì)承載如計(jì)算、存儲(chǔ)等實(shí)實(shí)在在的業(yè)務(wù)邏輯,同時(shí)由于現(xiàn)在微服務(wù)架構(gòu)的流行,前端應(yīng)用往往會(huì)承擔(dān)很重的膠水邏輯,即將各個(gè)微服務(wù)的邏輯串聯(lián)在一起,從而跑通業(yè)務(wù)流程。

因此,前端在編寫(xiě)usecase的時(shí)候,我們會(huì)更注重主子函數(shù)的拆分,讓主usecase更純粹的去描述業(yè)務(wù)流程,而將部分具體的實(shí)現(xiàn)拆分到子函數(shù)中去實(shí)現(xiàn)。

/*
    usecase聚焦流程的描述,諸如url鏈接拼接、活動(dòng)期查詢等具體邏輯都拆分到了其他的模塊中
*/
async function exportActivityLog({count, formValues}: {count: number;formValues: LogData}) {
  if (count > 5000) {
    message.error('導(dǎo)出文件數(shù)量不得超過(guò)5000!')
    return
  }
  const res = await checkIsDuringTheEventApi()
  if (res.isDuring) {
    message.error('活動(dòng)期間,功能暫不可用,如有疑問(wèn)聯(lián)系運(yùn)營(yíng)');
    return
  }
  const url = generateDownloadUrl({ formValues })
  downloadExcelFile(url)
}


function generateDownloadUrl() {
  // 省略
}
因此,對(duì)usecase層寫(xiě)單測(cè),正是我們要找的最好切入點(diǎn),其既能滿足我們將業(yè)務(wù)文檔進(jìn)行補(bǔ)充,同時(shí)又能有單測(cè)模塊的產(chǎn)出,保障我們的代碼質(zhì)量和程序的穩(wěn)定性。

4

單測(cè)實(shí)踐

在識(shí)別出要覆蓋單測(cè)的代碼模塊之后,下一步自然就是落地單測(cè)用例。

前面已說(shuō)過(guò),寫(xiě)單測(cè)本身就有一定的門(mén)檻,但既然要寫(xiě)就應(yīng)寫(xiě)可維護(hù)性和穩(wěn)定性高的單測(cè)。否則代碼稍微一重構(gòu),單測(cè)崩了;或代碼真崩了的時(shí)候,單測(cè)卻沒(méi)又通過(guò)了。

根據(jù)前面的描述可以看出,我們對(duì)于用例的可讀性(文檔性)和穩(wěn)定性有極高的訴求,對(duì)于用例所測(cè)試的邏輯范圍要求不高,這個(gè)準(zhǔn)則對(duì)于后續(xù)的單測(cè)用例的設(shè)計(jì)取舍會(huì)有很大的影響。

4.1 用例設(shè)計(jì)

首先我們需要確定設(shè)計(jì)用例的切入點(diǎn),目前單測(cè)社區(qū)內(nèi)比較流行的模式無(wú)非TDD和BDD兩種: TDD:測(cè)試驅(qū)動(dòng)開(kāi)發(fā),偏向于去測(cè)到函數(shù)的各個(gè)功能運(yùn)行的結(jié)果是否符合預(yù)期,由于是通過(guò)先寫(xiě)用例去驅(qū)動(dòng)業(yè)務(wù)邏輯的實(shí)現(xiàn),因此用例的設(shè)計(jì)往往更偏技術(shù)實(shí)現(xiàn)。 BDD:行為驅(qū)動(dòng)開(kāi)發(fā),流程上是TDD模式的一種分支,區(qū)別在于在構(gòu)思用例的時(shí)候更多的是以用戶行為(user story)的角度去考慮。

7928282a-85ec-11ed-bfe3-dac502259ad0.png

關(guān)于兩者更多的區(qū)別,大家可以網(wǎng)上查閱到更多的資料,這里就不再贅述。為了我們單測(cè)的穩(wěn)定可維護(hù)性,且以文檔為導(dǎo)向的我們,自然是選用了BDD的模式,只測(cè)業(yè)務(wù)行為邏輯,不關(guān)注功能函數(shù)的輸出正確與否(這塊目前可在自測(cè)和測(cè)試兄弟團(tuán)隊(duì)那邊幫忙保障)。這樣除非業(yè)務(wù)流程發(fā)生變更,否則代碼一般的重構(gòu)或調(diào)整都不會(huì)影響到單測(cè)的運(yùn)行,不會(huì)造成單測(cè)的雪崩。

4.2 用例結(jié)構(gòu)

在用例結(jié)構(gòu)上,為了配合“單測(cè)即文檔”的初衷并更好的配合BDD,我們?cè)谏鐓^(qū)常見(jiàn)的AAA(Arrange-Act-Assert)和GWT(Given-When-Then)兩種結(jié)構(gòu)之間選擇了后者。

無(wú)論AAA還是GWT最終都會(huì)形成一個(gè)三段式的用例結(jié)構(gòu),其區(qū)別仍然在于AAA的構(gòu)思更傾向于技術(shù)實(shí)現(xiàn),GWT更傾向于業(yè)務(wù)流程。雖然結(jié)構(gòu)一樣,但設(shè)計(jì)出來(lái)的用例內(nèi)容會(huì)有很大區(qū)別。

Given-When-Then

Given:一個(gè)上下文,指定和準(zhǔn)備測(cè)試的預(yù)設(shè)

When:進(jìn)行一系列操作,即所要執(zhí)行的操作

Then:得到可觀察的結(jié)果,即需要檢測(cè)的斷言

我們根據(jù)GWT的提供了單測(cè)的基本模板,供組內(nèi)同學(xué)寫(xiě)單測(cè)時(shí)直接使用。

function init() {
  const checkIsDuringTheEventApi = jest.fn();
  const downloadExcelFile = jest.fn();
  const exportActivityLog = buildMakeExportActivityLog({checkIsDuringTheEventApi, downloadExcelFile})


  return {
    checkIsDuringTheEventApi,
    downloadExcelFile,
    exportActivityLog
  }
}


describe('spec', () => {
  it('test', () => {
    // Given  準(zhǔn)備用例所需的上下文
    const { checkIsDuringTheEventApi, downloadExcelFile, exportActivityLog } = init();


    // When 調(diào)用待測(cè)的函數(shù)
    exportActivityLog()


    // Then  斷言
    expect('expect')
  })
})
對(duì)于一些校驗(yàn)簡(jiǎn)單模型的用例,通過(guò)init函數(shù)做一層封裝就夠用了。但對(duì)于業(yè)務(wù)邏輯比較復(fù)雜,字段比較多的模型,直接利用原生數(shù)據(jù)進(jìn)行初始化對(duì)用例的可讀性并不友好。
describe('spec', () => {
  it('個(gè)人賣(mài)家未發(fā)貨的訂單,允許進(jìn)行取消操作', () => {
    // Bad case: 依賴(lài)字段較多,這樣手動(dòng)去創(chuàng)造字段數(shù)據(jù)可讀性并不友好
    // 若case較多,這些字段要手動(dòng)構(gòu)建多次
    action({
      status: Status.待發(fā)貨,
      merchantType: MerchantType.個(gè)人賣(mài)家,
      // ...還有一些其他必傳字段
    })
  })
}
對(duì)于這種復(fù)雜場(chǎng)景,我們傾向于使用builder模式來(lái)構(gòu)造數(shù)據(jù),在較小的開(kāi)發(fā)成本下保障用例的可讀性和可維護(hù)性。

describe('spec', () => {
    it('個(gè)人賣(mài)家未發(fā)貨的訂單,允許進(jìn)行取消操作', () => {
        // Good case:通過(guò)builder實(shí)現(xiàn)邏輯的復(fù)用和信息的聚焦
        const order = new OrderBuilder()
          .status("待發(fā)貨")
          .merchantType("個(gè)人賣(mài)家")
          .build()


        action(order)


    })
})

4.3 用例描述

既然是要作為文檔使用,那用例描述上也顯得至關(guān)重要了。相比TDD對(duì)功能函數(shù)的單測(cè),我們描述完全于GWT的用例結(jié)構(gòu)對(duì)應(yīng)(When時(shí)常會(huì)被省略掉),我們并不關(guān)心具體的技術(shù)實(shí)現(xiàn)細(xì)節(jié),更多的是描述的這個(gè)業(yè)務(wù)的行為流程,思考函數(shù)最終想做什么,達(dá)到什么目的?;?strong>意圖,把被測(cè)函數(shù)當(dāng)做黑盒,不用關(guān)注其中間的實(shí)現(xiàn)細(xì)節(jié),究竟生成了什么臨時(shí)變量、循環(huán)了幾次、有什么判斷等,而是通過(guò)用例描述將業(yè)務(wù)流程講清楚。

describe('導(dǎo)出活動(dòng)日志', () => {
  it('導(dǎo)出時(shí),先查詢當(dāng)前活動(dòng)狀態(tài),若狀態(tài)是未在進(jìn)行中,則執(zhí)行導(dǎo)出操作', () => {
    // 省略...
  })
  it('導(dǎo)出時(shí),若導(dǎo)出數(shù)量大于5000條,將不允許導(dǎo)出', () => {
    // 省略...
  })
})

上面是導(dǎo)出活動(dòng)日志的一個(gè)操作,可以看出,用例的描述不會(huì)像測(cè)功能函數(shù)那樣精簡(jiǎn)(入?yún)⑹莂,調(diào)用了啥函數(shù)必須返回b之類(lèi)),但是將導(dǎo)出活動(dòng)時(shí),相應(yīng)的調(diào)用流程和條件描述了出來(lái),這樣其他人在接手這塊業(yè)務(wù)時(shí),通過(guò)這個(gè)用例就能清楚知道在導(dǎo)出活動(dòng)日志時(shí)需求上有些什么限制以及要做的操作。

4.4 用例斷言

在確定好用例的設(shè)計(jì)思路和結(jié)構(gòu)之后,我們?cè)谟美男r?yàn)內(nèi)容上也做了一些取舍。針對(duì)社區(qū)上主導(dǎo)的經(jīng)典測(cè)試(Classical)和模擬測(cè)試(Mockist)兩大陣營(yíng),結(jié)合“單測(cè)即文檔“的理念,我們對(duì)于業(yè)務(wù)流程的驗(yàn)證訴求非常強(qiáng)烈,因此選擇了后者。

Classical風(fēng)格是盡可能的使用真實(shí)對(duì)象和函數(shù),讓函數(shù)以及依賴(lài)都真實(shí)的執(zhí)行;相對(duì)的,Mockist是想盡辦法去mock,主張將所調(diào)用的被測(cè)函數(shù)全部mock。存在即合理,兩個(gè)派各有利弊,并不存在一定誰(shuí)好誰(shuí)差。

要對(duì)用到的函數(shù)進(jìn)行mock,在保證用例可維護(hù)性的前提下(比如不mock文件路徑),我們需要對(duì)函數(shù)的依賴(lài)關(guān)系進(jìn)行整理。得益于團(tuán)隊(duì)整潔架構(gòu)的落地,目前應(yīng)用的usecase層都已經(jīng)通過(guò)依賴(lài)倒置對(duì)依賴(lài)關(guān)系做了很好的管理(usecase只依賴(lài)entity)。

export default function buildMakeExportActivityLog({checkIsDuringTheEventApi,downloadExcelFile}) {
  async function exportActivityLog({count,formValues}) {
    if (count > 5000) {
      message.error('導(dǎo)出文件數(shù)量不得超過(guò)5000!')
      return
    }
    const res = await checkIsDuringTheEventApi()
    if (res.isDuring) {
      message.error('活動(dòng)期間,功能暫不可用,如有疑問(wèn)聯(lián)系運(yùn)營(yíng)');
      return
    }
    const url = generateDownloadUrl({ formValues })
    downloadExcelFile(url)
  }
}


// index.ts
import {checkIsDuringTheEventApi} from '@/services/activity'
import {downloadExcelFile} from '@/utils'
import buildMakeExportActivityLog from './makeExportActivityLog'


export const exportActivityLog = buildMakeExportActivityLog({cancel,printSaleTicket})
可以看到checkIsDuringTheEventApi以及downloadExcelFile這兩個(gè)函數(shù)最終作為參數(shù)傳入到實(shí)際的函數(shù)中,他們一個(gè)將會(huì)去發(fā)起請(qǐng)求,一個(gè)是會(huì)調(diào)用window的方法進(jìn)行下載,通過(guò)依賴(lài)倒置就能方便我們對(duì)其進(jìn)行模擬,在單測(cè)時(shí)就不會(huì)去真實(shí)執(zhí)行這兩個(gè)函數(shù)。
function init() {
  const checkIsDuringTheEventApi = jest.fn();
  const downloadExcelFile = jest.fn();
  const exportActivityLog = buildMakeExportActivityLog({checkIsDuringTheEventApi, downloadExcelFile})
  return {
    checkIsDuringTheEventApi,
    downloadExcelFile,
    exportActivityLog
  }
}
usecase中時(shí)常會(huì)有依賴(lài)的函數(shù)要去發(fā)起請(qǐng)求,在單測(cè)時(shí)我們不會(huì)去真實(shí)去發(fā)起這個(gè)請(qǐng)求,因此對(duì)于這類(lèi)函數(shù),我們都應(yīng)mock掉,這樣可保障我們用例的速度和穩(wěn)定性。當(dāng)然實(shí)際在寫(xiě)單測(cè)中,我們也不應(yīng)該成為一個(gè)完全的mockist,無(wú)休止的進(jìn)行mock,更好的方式是兩者結(jié)合,否則濫用mock反而會(huì)導(dǎo)致單測(cè)寫(xiě)起來(lái)會(huì)更繁瑣(因?yàn)橐ock所有調(diào)用的函數(shù)實(shí)現(xiàn)或場(chǎng)景),而且真實(shí)代碼寫(xiě)起來(lái)也會(huì)很別扭(所有外部函數(shù)都依賴(lài)倒置)。

一個(gè)用例正確與否,最終依賴(lài)的是最后的斷言,那對(duì)我們來(lái)說(shuō)該怎樣進(jìn)行斷言呢,如前面一直強(qiáng)調(diào)的一樣,我們測(cè)的是邏輯行為,因此需斷言的是某個(gè)行為的是否執(zhí)行或者是否達(dá)到了什么目的。結(jié)合前面的mock,我們可對(duì)函數(shù)的調(diào)用情況進(jìn)行捕獲,針對(duì)上面發(fā)起取消退款的函數(shù),斷言的例子如下:

describe('導(dǎo)出活動(dòng)日志', () => {
  it('導(dǎo)出時(shí),先查詢當(dāng)前活動(dòng)狀態(tài),若狀態(tài)是未在進(jìn)行中,則執(zhí)行導(dǎo)出操作', () => {
    // 省略...
    expect(downloadExcelFile).toBeCalled()
  })


  it('導(dǎo)出時(shí),若導(dǎo)出數(shù)量大于5000條,將不允許導(dǎo)出', () => {
    // 省略...
    expect(downloadExcelFile).not.toBeCalled();
  })
})

如上,斷言的內(nèi)容不是函數(shù)的實(shí)現(xiàn)細(xì)節(jié),如參數(shù)是否正確,而是只斷言行為是否執(zhí)行,它能盡量保證做到若代碼重構(gòu)后,單測(cè)用例在不修改的情況下依然能健壯的運(yùn)行,其只依賴(lài)需求的變更而做更改。同時(shí)為了維護(hù)用例的穩(wěn)定性,單個(gè)用例我們通常僅執(zhí)行一次斷言(單一職責(zé)),斷言的內(nèi)容嚴(yán)格和描述的“Then”部分對(duì)應(yīng)。

5

結(jié)語(yǔ)

商家以“單測(cè)即文檔”的理念為落地方向,在代碼設(shè)計(jì)以及用例的構(gòu)思、結(jié)構(gòu)、斷言、描述等環(huán)節(jié)都做了一定取舍,最終在用例的書(shū)寫(xiě)成本、穩(wěn)定性、可讀性等各個(gè)方面取得了相對(duì)較好的平衡。

目前組內(nèi)各個(gè)項(xiàng)目已逐漸沉淀了幾百個(gè)用例,團(tuán)隊(duì)內(nèi)相互支援或自己回顧時(shí),通過(guò)這些用例就能知道這塊邏輯在做什么事,在修改這些需求時(shí)通過(guò)測(cè)試用例也能盡快知道基本的業(yè)務(wù)邏輯,有了單測(cè)的保障,改起代碼來(lái)更有底氣,代碼結(jié)構(gòu)上,也更加的合理。在大家逐漸熟悉單測(cè)后,后續(xù)更會(huì)慢慢做到功能函數(shù)、UI等的單測(cè)覆蓋,大家一起來(lái)保障商家前端業(yè)務(wù)的穩(wěn)定發(fā)展。





審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 邏輯電路
    +關(guān)注

    關(guān)注

    13

    文章

    494

    瀏覽量

    42661
  • TDD
    TDD
    +關(guān)注

    關(guān)注

    1

    文章

    122

    瀏覽量

    38219
  • BDD
    BDD
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    7542

原文標(biāo)題:?jiǎn)螠y(cè)在商家前端業(yè)務(wù)中的實(shí)踐

文章出處:【微信號(hào):OSC開(kāi)源社區(qū),微信公眾號(hào):OSC開(kāi)源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    基于電信業(yè)務(wù)的程序設(shè)計(jì)課程改革探索與實(shí)踐

    【摘要】:本文針對(duì)我國(guó)大學(xué)程序設(shè)計(jì)課程教學(xué)存在的問(wèn)題,以通信工程專(zhuān)業(yè)為背景,提出將專(zhuān)業(yè)知識(shí)與程序設(shè)計(jì)課程相結(jié)合的改革思路,指出根據(jù)專(zhuān)業(yè)特點(diǎn)優(yōu)化課程教案、豐富課堂案例的方法,介紹了電信業(yè)務(wù)硬件平臺(tái)
    發(fā)表于 04-24 10:06

    GMTC 大前端時(shí)代前端監(jiān)控的最佳實(shí)踐

    系統(tǒng)。(這時(shí)候你就會(huì)想)要是能知道用戶報(bào)了什么錯(cuò)就好了。別怕,打開(kāi)阿里云前端監(jiān)控的【訪問(wèn)明細(xì)】搜索用戶ID,直接可以看到該用戶訪問(wèn)過(guò)程,到底報(bào)了什么錯(cuò)。有時(shí)候拿到了用戶報(bào)錯(cuò)時(shí)的基本信息,也知道用戶
    發(fā)表于 07-04 16:12

    OpenHarmony例模式實(shí)踐

    概念在軟件世界里面,實(shí)例是一個(gè)非常重要的概念。比如一個(gè)國(guó)家只有一個(gè)主席/總統(tǒng)/...一支軍隊(duì)只有一個(gè)最高統(tǒng)帥一個(gè)班級(jí)只有一個(gè)班主任...OpenHarmony實(shí)踐OpenHarmony是如何實(shí)現(xiàn)
    發(fā)表于 09-15 09:27

    國(guó)產(chǎn)射頻前端芯片

    AT2402E 是一款應(yīng)用于無(wú)線通信的集成收發(fā)功能的射頻前端芯片,芯片 內(nèi)部集成了所需要的射頻電路模塊,集成度非常高,主要包括功率放大器(PA), 低噪聲放大器(LNA),收發(fā)模式切換的開(kāi)關(guān)
    發(fā)表于 02-02 15:16

    業(yè)務(wù)規(guī)則管理電信網(wǎng)管系統(tǒng)的應(yīng)用

    主要介紹業(yè)務(wù)規(guī)則及業(yè)務(wù)規(guī)則管理的概念,討論了業(yè)務(wù)規(guī)則管理系統(tǒng)的基本原理,實(shí)踐一個(gè)簡(jiǎn)單的業(yè)務(wù)規(guī)則管理系統(tǒng)并應(yīng)用于電信網(wǎng)絡(luò)管理系統(tǒng)
    發(fā)表于 06-19 11:57 ?17次下載

    Ku波段接收前端抗干擾方法淺析

    Ku波段接收前端抗干擾方法淺析,下來(lái)看看。
    發(fā)表于 07-29 19:05 ?6次下載

    高通宣布與谷歌、hTC、三星和索尼移動(dòng)射頻前端業(yè)務(wù)方面展開(kāi)合作

    射頻前端對(duì)終端用戶對(duì)其設(shè)備的移動(dòng)體驗(yàn)至關(guān)重要,并能夠促進(jìn)移動(dòng)行業(yè)的未來(lái)發(fā)展。過(guò)去的一年,高通射頻前端領(lǐng)域可謂動(dòng)作頻頻,經(jīng)過(guò)一系列的合作,如今終于迎來(lái)一波重要的合作伙伴。今天CES的
    的頭像 發(fā)表于 01-10 16:22 ?4521次閱讀

    web前端開(kāi)發(fā)實(shí)踐的目錄推薦

    本文檔的主要內(nèi)容詳細(xì)介紹的是web前端開(kāi)發(fā)實(shí)踐的目錄推薦。
    發(fā)表于 01-31 08:00 ?0次下載

    淺析風(fēng)速傳感器氣象監(jiān)測(cè)的重要作用

    淺析風(fēng)速傳感器氣象監(jiān)測(cè)的重要作用
    發(fā)表于 11-03 17:25 ?12次下載

    淺析高壓放大器絕緣電阻電痕腐蝕程度分析的應(yīng)用

    淺析高壓放大器絕緣電阻電痕腐蝕程度分析的應(yīng)用
    發(fā)表于 01-14 10:00 ?5次下載

    淺析質(zhì)構(gòu)儀還原劑對(duì)熟化陳米品質(zhì)影響研究的應(yīng)用

    淺析質(zhì)構(gòu)儀還原劑對(duì)熟化陳米品質(zhì)影響研究的應(yīng)用
    發(fā)表于 01-18 09:20 ?4次下載

    淺析低功耗應(yīng)用克服低IQ挑戰(zhàn)

    淺析低功耗應(yīng)用克服低IQ挑戰(zhàn)
    發(fā)表于 02-10 09:56 ?2次下載

    加快部署 5G 基站的最佳實(shí)踐:RF 前端大規(guī)模 MIMO 入門(mén)

    加快部署 5G 基站的最佳實(shí)踐:RF 前端大規(guī)模 MIMO 入門(mén)
    的頭像 發(fā)表于 12-26 10:16 ?1843次閱讀
    加快部署 5G 基站的最佳<b class='flag-5'>實(shí)踐</b>:RF <b class='flag-5'>前端</b>大規(guī)模 MIMO 入門(mén)

    前端大數(shù)據(jù)產(chǎn)品的應(yīng)用背景和應(yīng)用原理

    ? 導(dǎo)讀: 本文由梯度科技前端研發(fā)部高級(jí)開(kāi)發(fā)工程師賀信撰寫(xiě),主要介紹如何基于前沿開(kāi)源的前端技術(shù)方案實(shí)現(xiàn)微前端大數(shù)據(jù)平臺(tái)中的應(yīng)用落地,并對(duì)所取得的應(yīng)用效果進(jìn)行剖析。主要包括以下幾個(gè)方面
    的頭像 發(fā)表于 08-14 15:18 ?1321次閱讀
    微<b class='flag-5'>前端</b><b class='flag-5'>在</b>大數(shù)據(jù)產(chǎn)品<b class='flag-5'>中</b>的應(yīng)用背景和應(yīng)用原理

    遞歸算法實(shí)踐--到倉(cāng)合助力京東物流提效增收

    作者:京東物流 李碩 一、背景 京東物流到倉(cāng)業(yè)務(wù)「 對(duì)商家 」為了減少商家按照京東采購(gòu)分貨備貨過(guò)程,對(duì)齊行業(yè)直接按照流向交接,提升商家滿意
    的頭像 發(fā)表于 01-09 14:57 ?103次閱讀