vue大型電商項目尚品匯(後臺篇)day03

来源:https://www.cnblogs.com/heymar/archive/2022/06/17/16387208.html
-Advertisement-
Play Games

今天把平臺屬性的管理基本完成了,後臺管理做到現在基本也開始熟悉,確實就是對ElementUI的一個熟練程度。 一.平臺屬性管理 1.動態展示數據 先把介面弄好,應該在第三級標題選擇後進行發請求 靜態頁面搭建 渲染數據 屬性值列表,用到一個新組件 tag,並且這裡有多個屬性值,所以要遍歷,既然要在裡面 ...


今天把平臺屬性的管理基本完成了,後臺管理做到現在基本也開始熟悉,確實就是對ElementUI的一個熟練程度。

一.平臺屬性管理

1.動態展示數據

先把介面弄好,應該在第三級標題選擇後進行發請求

image-20220617094919282

靜態頁面搭建

image-20220617095422463

渲染數據

image-20220617095604777

屬性值列表,用到一個新組件 tag,並且這裡有多個屬性值,所以要遍歷,既然要在裡面加標簽那就要用slot,最後添加兩個圖標

image-20220617100338113

image-20220617100344888

2.添加與修改屬性(靜態)

點擊添加修改應該將下麵的表格組件隱藏出來一個新的組件

image-20220617101330520

如果沒有選擇到三級分類的時候,添加屬性按鈕應該不可點

image-20220617101510845

新的頁面佈局

image-20220617110603682

image-20220617110609790

點擊取消應該回到列表展示界面

image-20220617110702260

3.收集平臺屬性

首先我們的介面需要的數據,這裡要註意我們categoryId是收集categoty3的id,但是這裡不能用this.category3Id因為data裡面數據聲明賦值是亂序的,所以會出現undefined

image-20220617113057253

先收集屬性名

image-20220617113207243

在收集屬性值

table數據指向子級list,屬性值應該為一個input框收集內容

image-20220617114731418

預設進來應該為空只有當點擊添加才會出現,那麼應該給子級list裡面的長度為0,因為table綁定的這個數據,當我們點擊新增再去push

註意id應該為undefined,因為我們只是占位,添加過後給到後端,他才會賦值你的id

image-20220617115204051

當我們屬性名沒有內容時,新增屬性值按鈕應該為disabled

image-20220617115335259

image-20220617115358606

image-20220617115405915

4.返回按鈕數據回顯問題

當點擊取消,再點擊添加屬性,我們剛纔編輯的內容還在

就是添加屬性進來應該清空一下內容

image-20220617153545324

並且順便還可以把3Id在這裡收集了

image-20220617153711400

5.修改屬性操作(面試重點深淺拷貝複習)

點擊修改按鈕,把傳進來的row參數直接賦值給

image-20220617154915076

但是這裡會有問題,當我們修改了內容不點保存點擊取消,會發現新的內容會保存下來,其原理跟前面指向問題那裡一樣,因為row是伺服器返回來的數據,我們的table也基於這個數據在渲染,你現在點擊修改將baseAttrInfo賦值給了row,相當於table渲染的數據和baseAttrInfo都指向了同一個數組,所以在記憶體裡面要修改都會被修改

image-20220617155112333

先回顧一下深淺拷貝,這兩個必須達到手寫出來的程度

淺拷貝,也可以利用es6語法object.assign方法來實現,前面參數老對象後面參數新對象,還可以使用之前用的方法{...obj}擴展運算符出來,又賦值一個新對象

一定要註意淺拷貝只拷貝一層,深層次的內容只拷貝引用,意思就是新對象可以得到這個內容,但是由於只是引用所以新對象修改,老對象深層次的內容也會被修改

image-20220617155829032

然後是深拷貝,他就是可以拷貝多層,而且深層次的內容開闢新的空間,各管各的,要實現深拷貝用到一個核心內容就是遞歸

image-20220617161004895

所以回到項目上面來,我們這裡這個數據能像之前那樣直接使用淺拷貝嗎

image-20220617161308571

很明顯涉及到深層次數據了,所以這裡直接用深拷貝,用到lodash的深拷貝

image-20220617162353252

image-20220617162347429

6.查看模式與修改模式切換

當點擊修改進來attrId應該為當前這個屬性的id

image-20220617193427966

所以我新增的這個屬性也應該有id,這樣當我們的如果是修改進入就是這個id,如果是直接新增一個新的屬性,那麼沒有這個id值就為undefined

image-20220617193504803

什麼叫做查看模式與修改模式

當我點擊添加應該有一個input框當我失去焦點應該轉為一個span來呈現,兩者勢不兩立應該用v-if和v-else來展示

image-20220617195331968

註意這裡並不能統一在data定義一個flag來作為切換的依據,因為如果都用它那麼當我有多條數據的時候,我切換就變成了全部一起切換了

這裡有個技巧就是,當我在push一條新數據,點擊添加新對象的時候,給每一條數據單獨添加一個flag

image-20220617195827937

image-20220617195835015

失去焦點、以及回車都會切換到查看模式,註意這裡是組件標簽所以系統事件也是自定義事件要先加native再加enter才行

image-20220617200538295

然後是查看模式雙擊事件切換到修改模式

image-20220617201245916

註意事項:

  • 一個是如果我們輸入的空白值不允許保存切換

image-20220617205714700

image-20220617205934669

  • 還有一個問題就是,如果是重覆的值也不能切換,這裡用some方法來做,some和every的區別回顧一下,還有這裡有個問題,我們對當前子級list做一個遍歷,而且邏輯是寫在blur裡面的,所以這個時候我們新的數據,也就是row已經生成,那麼我們some就會遍歷到他,那麼你在裡面判斷的時候應該排除掉他,不然的話每一個item進來永遠都有一個相等的

    image-20220617210742075

7.修改按鈕的查看與編輯切換

當我們點擊修改按鈕進入屬性操作,會發現無法進行查看與編輯的切換,也很正常,剛纔添加flag完全是在添加屬性這個按鈕裡面做的

所以我們就需要給修改按鈕的回調做一些操作

image-20220617212331031

如果像這樣做確實能添加上flag但並不會觸發視圖更新,因為我們前面的flag是通過push添加進行的,能夠被vue檢測到,而且還是響應式數據,而我們這裡直接加入進來,一個普通的數據並不會被vue檢測到改變,所以也就不會去重新解析模板,這裡的做飯就是用$set添加響應數據即可

image-20220617212915384

8.表單元素自動聚焦

核心思想是給每個input打ref,而且值為$index,當我們從span切換到編輯的這個事件中,可以傳入這個時候index,也就是當前的input,利用nextTick就可以讓切換過後的input馬上聚焦

image-20220617214756663

因為index是動態參數所以這裡對象只能採用【】這種形式

image-20220617214942573

然後就是我們每一次點擊新增屬性也應該聚焦,而且是聚焦最後一個

image-20220617215232646

9.刪除屬性值

用到一個新組件氣泡框 Popconfirm

image-20220617220600963

註意一下,這裡模板用的elementUI是2.13.2版本,官網是最新版本,所以對於氣泡框的事件名有出入

image-20220617220747130

註意splice方法

image-20220617221006027

10.保存操作

平臺屬性最後一步就是編輯完成保存操作,在這一步準備發請求了,但是在發請求之前要先整理一下參數

首先我們的參數要確保不能有空的內容

image-20220617221649000

另外就是我們的請求的參數數據是不需要flag還要把他刪除了,直接delete可以刪除對象的屬性

image-20220617221958129

然後就可以發請求

image-20220617222556312


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 一、Termux 1.Termux簡介 Termux是 Android 平臺上的一個終端模擬器,之所以稱它為“模擬器”而非“虛擬機”,是因為它並非像 PC 端的 VirtualBox 等虛擬機軟體那樣,在宿主機中虛擬出一個完全獨立且完整的系統環境 ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 前言 開始搭建RK3568的基礎虛擬機,具備基本的通用功能,主要包含了串口工具minicom,遠程登陸ssh,遠程傳輸filezilla,代碼編輯工具vscode。 虛擬機 文檔對對虛擬機做了一些基本要求,如下圖: 為了儘量在前期減少錯誤,應選擇 ...
  • 下載證書 申請證書 證書下載 文件格式為: PEM格式的證書文件。 PEM格式的證書文件是採用Base64編碼的文本文件,您可以根據需要將證書文件修改成其他格式。 KEY格式的證書私鑰文件。 安裝證書 登錄Linux 證書上傳到伺服器 新建存放證書的目錄 mkdir /usr/local/nginx ...
  • CentOS目前官網提供的下載版本有6、7、8,最新的版本為8,不過個人推薦CentOS 7 的版本,因為相比較於最新版本,版本7更加地穩定。而相比於版本6,版本7新增了很多的功能。CentOS 7 是目前主流的版本,穩定成熟,是大多數伺服器首選的版本。話不多說,直入主題。 下載centos官方鏡像 ...
  • 唉。下麵是我花了不知道多少個小時踩過的所有坑總結出來的血淚史,希望能幫你們少踩一些坑吧,正常來講一步一步下來就不會出現任何問題了。 背景 用的是百度雲的雲伺服器(其他雲伺服器同理),系統是Ubuntu 20.04 LTS,Mysql版本8.0+,需求是在Windows上開發,可以隨時遠程連接讀寫服務 ...
  • 分享嘉賓:張政 京東 演算法工程師 編輯整理:AMS 周金星 出品平臺:DataFunTalk 導讀: 內容生態建設是近幾年互聯網快速發展的關鍵動因,也是AI化的重點方向之一。本文主要分享在京東廣告業務下內容理解體系的建設情況,從標簽化、內容準入、質量美學評價等多個角度探討內容理解能力的應用;同時整體 ...
  • SQL的函數 函數的定義 函數是指一段可以直接被另一段程式調用的程式或代碼; 字元串函數 MySQL常用的字元串函數 函數 功能 concat(s1,s2,···sN) 字元串拼接,將s1···sN拼接為一個字元串 lower(str) 將字元串str全部轉換為小寫 upper(str) 將字元串s ...
  • 華為應用內支付服務(In-App Purchases,IAP)為開發者提供便捷的應用內支付體驗和簡便的接入流程。開發者的應用集成IAP SDK後,調用IAP SDK介面,啟動IAP收銀台,即可實現應用內支付。在集成過程中,開發者可能會遇到報錯的問題,這時我們可以通過查找日誌中的tag的方法對問題快速 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...