cao死我好湿好紧好爽动态视屏|精选久久久久久久久久|中文无码精品一区二区三区四季|AAA国语精品刺激对白视频|

當前位置:首頁 > 軟件開放 > 正文內容

js樹形下拉菜單代碼(js 樹形菜單)

軟件開放6個月前 (06-30)378

編按:

一說起下拉菜單,我相信大多數(shù)有點Excel基礎的都會做。但今天我們來點不一樣的下拉菜單,從青銅級別到王者級別,應有盡有,趕緊來看一看吧!

下面,我們將按照從簡單到高級來給大家介紹如下幾種下拉菜單。

1、最簡單的下拉菜單

2、名稱制作下拉菜單

3、動態(tài)下拉菜單(沒有空白選項的)

4、多內容下拉菜單,填充時拆分內容

5、智能錄入下拉菜單,填充時拆分內容

注意:今天主要說的內容是“數(shù)據(jù)驗證(Validation)”的內容,不涉及控件使用,各個Excel版本都可以使用。

【正文】

1、青銅(最簡單的下拉菜單)

制作方法:

在工具欄中,點擊“數(shù)據(jù)驗證”功能;

展開全文

在彈出的窗口中,按下圖:

在【允許】中選擇“序列”,在【來源】中輸入“男,女”,按確定鍵完成操作。

注意:無論選填的內容是什么,都要用“英文的逗號間隔”,而且不需使用雙引號。

2、白銀

方法1:在數(shù)據(jù)驗證窗口中,如下設置

【來源】處可以直接選擇單元格區(qū)域,即可把這部分的內容作為下拉菜單的內容。

方法2:我們也可以使用名稱管理器來操作:

選擇A2:A17單元格,然后在【名稱框】中編輯一個名稱:例如我們輸入“科學家”,然后【按回車結束編輯】

然后在數(shù)據(jù)驗證窗口中如下圖設置;

3、黃金——動態(tài)下拉菜單

如果我們的選擇項數(shù)量不確定,隨著添加或者刪除,下拉選項也要隨之增加減少,如下圖所示:

按CTRL+F3組合鍵,打開【名稱管理器】窗口,新建一個名稱“選項”,按下圖設置名稱內容:

引用位置的函數(shù):=OFFSET(黃金!$A$2,,,COUNTA(黃金!$A$2:$A$997),)

使用COUNTA函數(shù)確定區(qū)域中的內容數(shù)量,然后在使用數(shù)據(jù)驗證創(chuàng)建下拉菜單即可。

如果A列數(shù)據(jù)是使用函數(shù)后得到的,例如把某列數(shù)據(jù)去重,如下圖:

A2單元格的函數(shù)為:

{=IFERROR(INDEX($A$2:$A$38,SMALL(IF(MATCH($A$2:$A$38,$A$2:$A$38,0)=ROW($1:$37),ROW($1:$37),9^9),ROW(B1))),"")}

這個函數(shù)是萬金油,之前的教程中有解釋的,就不在這里贅述了。然后下拉A2單元格填充至A18,就得到了去重后的內容,然后再使用名稱即可引用到數(shù)據(jù)驗證中。

但是要注意:表中從B8:B18都是IFERROR函數(shù)容錯后的空格,那么剛才用COUNTA函數(shù)引出選項個數(shù)的方式就不正確了,我們換一個寫法即可,如下:

函數(shù)如下:

=OFFSET(黃金!$B$2,,,COUNTA(黃金!$B$2:$B$18)-COUNTBLANK(黃金!$B$2:$B$18),)

用COUNTA-COUNTBLANK的方式確定應該取多少個選項內容。

截止到此,【下拉選填菜單】的操作方法,配合【函數(shù)】和【自定義名稱】還可以適應工作,但是已經顯得力不從心,因為隨著數(shù)據(jù)的變化,對于函數(shù)和自定義名稱的調整是在所難免的。那么【更高級別的下拉選填菜單】我們繼續(xù)看。

js樹形下拉菜單代碼(js 樹形菜單)

4、鉆石級別——多內容下拉菜單,填充時拆分內容

下拉菜單選擇項包含多個不同屬性的內容,選填后自動填入多個單元格。這個方式是使用VBA操作的,代碼如下:

Private Sub Worksheet_Change(ByVal Target As Range) '''單元格值改變,觸發(fā)事件

If Target.Column = 4 And Target.Count = 1 Then '''判斷是否在D列,選擇一個單元格

With Target '''使用這個單元格

s = .Text '''單元格的值賦值給一個變量s

.Resize(1, 2) = Split(s, ":") '''單元格擴展1行2列,然后把用Split函數(shù)按冒號拆分的數(shù)組賦值到單元格區(qū)域

End With '''with結束語句

End If '''結束判斷

End Sub '''工程結束

Private Sub Worksheet_SelectionChange(ByVal Target As Range) '''選擇單元格改變,觸發(fā)事件

If Target.Column = 4 And Target.Count = 1 Then '''判斷是否在D列,選擇一個單元格

With Sheets("鉆石")

s = Join(Application.Transpose(.Range("A2:A" .[A65000].End(3).Row)), ",") '''將A列從A2開始,有值的單元格Join成一個字符串,用英文逗號間隔

End With

With Selection.Validation '對所選擇的單元格,創(chuàng)建數(shù)據(jù)有效性

.Delete

.Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:= _

xlBetween, Formula1:=s

.IgnoreBlank = True '設置單元格 允許空值

.InCellDropdown = True '提供下拉列標

End With

End If '結束判斷

End Sub '''工程結束

按下圖粘貼或者編寫代碼亦可。

5、王者——智能錄入下拉菜單,填充時拆分內容

同學們做過多級聯(lián)動的下拉菜單嗎?你是如何做的呢,按首行批量創(chuàng)建自定義名稱,然后再INDIRECT?

這種方法對于簡單的數(shù)據(jù)源還是可以采用的,但是對于比較多的內容就不是很方便,例如我們今天的這份數(shù)據(jù)源——“全國【省、市、縣 三層】的智能下拉填充功能”

如果同學們用傳統(tǒng)方式做的話,自定義名稱要做多少呢?

下面看看作者E圖表述制作后的效果吧:

這也是用VBA做的,VBA可以做很多日常不敢想想的內容,也只有VBA才能做出高級的功能。不說廢話,代碼如下:

Private Sub Worksheet_Change(ByVal Target As Range)

If Target.Column = 7 And Target.Row = 2 Then '''如果被改變值的單元格7行2列【G2】單元格時

With Sheets("王者") '''使用《王者》工作表

arr = .Range("A2:C" .[A100000].End(3).Row) '''將從A2單元格開始到A列已使用的末行結束的單元格區(qū)域賦值數(shù)值arr

s = Target.Text '''將被操作單元格的值賦值給變量s

If s "" Then '''如果s不為空值

For i = 1 To UBound(arr) '''循環(huán)數(shù)組arr

st = arr(i, 1) "|" arr(i, 2) "|" arr(i, 3) '''將省市縣內容合并,并且用|間隔

If st Like "*" s "*" Then '''如果st字符串包含s變量的內容

svd = svd st "," '''將st賦值給svd變量,并用英文逗號間隔,作為下拉菜單的內容

End If

Next i

End If

With .Range("G3").Validation '對G3單元格創(chuàng)建數(shù)據(jù)有效性

.Delete

.Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:= _

xlBetween, Formula1:=svd

.IgnoreBlank = True '設置單元格 允許空值

.InCellDropdown = True '提供下拉列標

End With

.[G3] = "" '''G3單元格初始值為空

End With

End If

If Target.Column = 7 And Target.Row = 3 And Target.Text "" Then '''如果G3單元格的值被改變,且值不為空時

With Sheets("王者")

a = .[H100000].End(3).Row + 1 '''確定H列中為空的第一行

.Cells(a, 8) = Split(Target.Text, "|")(0) '''Split方法拆分下拉菜單的內容,將第1個值放入第8列的末行空白行

.Cells(a, 9) = Split(Target.Text, "|")(1) '''同上,放入第2個值

.Cells(a, 10) = Split(Target.Text, "|")(2) '''同上,放入第3個值

'''注意:Split方法拆分后,是一個一維數(shù)組。vba中的內存數(shù)組序號默認是從0開始計數(shù)的

.[G3] = "" '''G3單元格再歸零

End With

End If

End Sub

不需自定義名稱,不需多級聯(lián)動的大量數(shù)據(jù)驗證,這將極大的節(jié)省EXCEL的內存,大大提高了運行的效率,同時一級選擇、多級錄入的方式也節(jié)省了操作的環(huán)節(jié)。

寫在最后:王者只是人間的強者,而這世間還有更高的存在。人外人、天外天,EXCEL之外有EXCEL,除開上面這種“下拉菜單”,我們還有更高級別的,大家想不想看呢?

做Excel高手,快速提升工作效率,部落窩教育《一周Excel直通車》視頻和《Excel極速貫通班》直播課全心為你!

學習交流請加微信:hclhclsc進微信學習群。

相關推薦:

如何制作智能的下拉菜單?輸入數(shù)據(jù)模糊匹配對應的下拉選項

最簡單的多級下拉菜單制作方法,不需要定義名稱

別怕,VBA入門級教程來了,條件語句很簡單!

八大查找函數(shù)公式,輕松搞定數(shù)據(jù)中的多條件查找

版權申明:

本文作者E圖表述;同時部落窩教育享有專有使用權。若需轉載請聯(lián)系部落窩教育。

掃描二維碼推送至手機訪問。

版權聲明:本文由飛速云SEO網絡優(yōu)化推廣發(fā)布,如需轉載請注明出處。

本文鏈接:http://www.smallwaterjetsystem.com/post/117684.html

分享給朋友:

“js樹形下拉菜單代碼(js 樹形菜單)” 的相關文章

延安軟件開發(fā)公司(延安軟)

延安軟件開發(fā)公司(延安軟)

本篇文章給大家談談延安軟件開發(fā)公司,以及延安軟對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、陜西延安藍島電腦培訓是正規(guī)的學校嗎?培訓完有畢業(yè)證書嗎? 2、延安軟件開發(fā)的培訓機構哪家比較好? 3、延安關于軟件的央企 4、方正國際軟件(長春)有限公司怎么樣?...

怎么創(chuàng)建網站(怎么建網站)

怎么創(chuàng)建網站(怎么建網站)

本篇文章給大家談談怎么創(chuàng)建網站,以及怎么建網站對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、如何創(chuàng)建自己的網站平臺 2、怎樣自己創(chuàng)建一個網站? 3、怎么創(chuàng)建網站 4、怎么建網站呀! 5、怎么創(chuàng)建一個自己的網站 如何創(chuàng)建自己的網站平臺 創(chuàng)建自己的網站平臺...

微信小程序跨境電商(微信小程序做跨境電商)

微信小程序跨境電商(微信小程序做跨境電商)

今天給各位分享微信小程序跨境電商的知識,其中也會對微信小程序做跨境電商進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關注本站,現(xiàn)在開始吧!本文目錄一覽: 1、至臻小程序是正品嗎 2、如何說明跨境電商市場潛力大 3、騰訊小鵝拼拼上線不到兩年就要關停 4、優(yōu)時通奶粉是正品嗎 至臻小程序是...

發(fā)行數(shù)字藏品需要什么手續(xù)(數(shù)字藏品能升值嗎)

發(fā)行數(shù)字藏品需要什么手續(xù)(數(shù)字藏品能升值嗎)

本篇文章給大家談談發(fā)行數(shù)字藏品需要什么手續(xù),以及數(shù)字藏品能升值嗎對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、數(shù)字藏品怎么制作 2、朋友支招怎么做數(shù)字藏品? 3、數(shù)字藏品銀行申請流程 4、用稀臺元宇宙saas經營數(shù)字藏品需要具備什么資質? 5、國家支持數(shù)...

交易平臺凍結資金讓充錢解凍怎么舉報(交易平臺資金凍結了需要充錢解凍嗎)

交易平臺凍結資金讓充錢解凍怎么舉報(交易平臺資金凍結了需要充錢解凍嗎)

今天給各位分享交易平臺凍結資金讓充錢解凍怎么舉報的知識,其中也會對交易平臺資金凍結了需要充錢解凍嗎進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關注本站,現(xiàn)在開始吧!本文目錄一覽: 1、游戲平臺把我的資金凍結了,要求我給他們打500過去才能解凍,不然會被永久凍結,該怎么辦,錢還能拿回 2、我在...

eclipse學java選哪個安裝(怎樣安裝java和eclipse)

eclipse學java選哪個安裝(怎樣安裝java和eclipse)

本篇文章給大家談談eclipse學java選哪個安裝,以及怎樣安裝java和eclipse對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、我是JAVA初學者Eclipse 用哪個版本? 2、想在Eclipse中學習javaswing開發(fā),請問要安裝哪些開發(fā)軟件 3...

法库县| 锡林郭勒盟| 五河县| 安乡县| 易门县| 石屏县| 新邵县| 西平县| 佛学| 收藏| 彭阳县| 通州区| 金平| 二连浩特市| 镇远县| 新源县| 宁国市| 垫江县| 曲麻莱县| 青河县| 萨嘎县| 米泉市| 东莞市| 平远县| 潼南县| 旅游| 北海市| 西平县| 左权县| 建湖县| 夏河县| 水富县| 南京市| 达拉特旗| 五指山市| 新疆| 屏边| 洱源县| 凉山| 临沂市| 清镇市|