91成人精品,神马影院东京干,国产一级做a爰片久久 亚洲日韩欧美一区二区三区_国产AV无码专区亚洲AV

首頁(yè)

CSS初學(xué):如何修改Zblog中的CSS

前端達(dá)人

在學(xué)習(xí)應(yīng)用css之前我們要先了解一下什么是css。CSS是Cascading Style Sheets(層疊樣式表)的簡(jiǎn)稱.


  • CSS語(yǔ)言是一種標(biāo)記語(yǔ)言,它不需要編譯,可以直接由瀏覽器執(zhí)行(屬于瀏覽器解釋型語(yǔ)言).


  • 在標(biāo)準(zhǔn)網(wǎng)頁(yè)設(shè)計(jì)中CSS負(fù)責(zé)網(wǎng)頁(yè)內(nèi)容(XHTML)的表現(xiàn).


  • CSS文件也可以說(shuō)是一個(gè)文本文件,它包含了一些CSS標(biāo)記,CSS文件必須使用css為文件名后綴.


  • 可以通過(guò)簡(jiǎn)單的更改CSS文件,改變網(wǎng)頁(yè)的整體表現(xiàn)形式,可以減少我們的工作量,所以她是每一個(gè)網(wǎng)頁(yè)設(shè)計(jì)人員的必修課.


  • CSS是由W3C的CSS工作組產(chǎn)生和維護(hù)的.



    新建一個(gè)前端學(xué)習(xí)qun438905713,在群里大多數(shù)都是零基礎(chǔ)學(xué)習(xí)者,大家相互幫助,相互解答,并且還準(zhǔn)備很多學(xué)習(xí)資料,歡迎零基礎(chǔ)的小伙伴來(lái)一起交流。



    了解了什么是css后我們就可以方便對(duì)其應(yīng)用了,我們可以用以下兩種方式加入你的博客當(dāng)中去,由于css的應(yīng)用方式有就近原則。也就是說(shuō)最接近目標(biāo)的樣式定義優(yōu)先權(quán)越高。高優(yōu)先權(quán)樣式將繼承低優(yōu)先權(quán)樣式的未重疊定義但覆蓋重疊的定義。



    鏈入外部樣式表文件 (Linking to a Style Sheet)



    你可以先建立外部樣式表文件(.css),然后使用HTML的link對(duì)象。示例如下:



    <head>

    <title>文檔標(biāo)題</title>

    <link rel=stylesheet href="http://www.123-seo,cn/dhtmlet.css" type="text/css">

    </head>



    而在XML中,你應(yīng)該如下例所示在聲明區(qū)中加入:



    <? xml-stylesheet type="text/css" href="http://www.123-seo.cn/dhtmlet.css" ?>



    定義內(nèi)部樣式塊對(duì)象 (Embedding a Style Block)



    你可以在你的HTML文檔的<HTML>和<BODY>標(biāo)記之間插入一個(gè)<STYLE>...</STYLE>塊對(duì)象。 定義方式請(qǐng)參閱樣式表語(yǔ)法。示例如下:



    <html>

    <head>

    <title>文檔標(biāo)題</title>

    <style type="text/css">

    <!--

    body {font: 10pt "Arial"}

    h1 {font: 15pt/17pt "Arial"; font-weight: bold; color: maroon}

    h2 {font: 13pt/15pt "Arial"; font-weight: bold; color: blue}

    p {font: 10pt/12pt "Arial"; color: black}

    -->

    </style>

    </head>

    <body>



    請(qǐng)注意,這里將style對(duì)象的type屬性設(shè)置為"text/css",是允許不支持這類型的瀏覽器忽略樣式表單。

    ————————————————

    版權(quán)聲明:本文為CSDN博主「html基礎(chǔ)教程」的原創(chuàng)文章,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。

    原文鏈接:https://blog.csdn.net/html168/article/details/104565043


CSS樣式表使用技巧充分利用樣式表的強(qiáng)大性

前端達(dá)人

為了提高網(wǎng)頁(yè)的維護(hù)更新效率,我們可以使用樣式表,來(lái)僅僅改變一個(gè)文件,就能達(dá)到同時(shí)改變幾百個(gè)網(wǎng)頁(yè)的外觀。為了能充分用好樣式表的強(qiáng)大性和靈活性,筆者就怎樣有效使用樣式表,來(lái)談?wù)勛约旱囊恍┬牡皿w會(huì)



 



隨著互聯(lián)網(wǎng)經(jīng)濟(jì)的不斷發(fā)展,互聯(lián)網(wǎng)上的專業(yè)網(wǎng)站、公眾服務(wù)網(wǎng)站以及企業(yè)門(mén)戶的數(shù)量都在飛速的增長(zhǎng),各網(wǎng)站的信息量也呈爆炸性增長(zhǎng)的趨勢(shì)。面對(duì)這些龐大的信 息量,我們對(duì)網(wǎng)頁(yè)中每一個(gè)欄目的增刪,都會(huì)是一個(gè)很復(fù)雜的過(guò)程。為了提高網(wǎng)頁(yè)的維護(hù)更新效率,我們可以使用樣式表,來(lái)僅僅改變一個(gè)文件,就能達(dá)到同時(shí)改變 幾百個(gè)網(wǎng)頁(yè)的外觀,而其個(gè)性化的表現(xiàn)未受任何損失。為了能充分用好樣式表的強(qiáng)大性和靈活性,筆者就怎樣有效使用樣式表,來(lái)談?wù)勛约旱囊恍┬牡皿w會(huì)。 新建一個(gè)前端學(xué)習(xí)qun438905713,在群里大多數(shù)都是零基礎(chǔ)學(xué)習(xí)者,大家相互幫助,相互解答,并且還準(zhǔn)備很多學(xué)習(xí)資料,歡迎零基礎(chǔ)的小伙伴來(lái)一起交流。



1、在一個(gè)網(wǎng)頁(yè)中同時(shí)調(diào)用CSS的多種引入方式 



在 HTML中引入CSS的方式很多,例如直接插入式,使用 鏈接外部樣式表,使用CSS"@import"導(dǎo)入樣式表以及在內(nèi)部元素中使用"STYLE"標(biāo)記來(lái)定義樣式表等。有網(wǎng)友詢問(wèn),這些引入方式能不能同時(shí)在 一個(gè)網(wǎng)頁(yè)中被調(diào)用,它們之間會(huì)不會(huì)產(chǎn)生混亂?其實(shí),我們大可不必這么擔(dān)心,這就是它為什么稱之為“層疊樣式表”的原因,瀏覽器在處理網(wǎng)頁(yè)中的樣式表是按照 一定的順序來(lái)處理的,首先檢查頁(yè)面中是否有直接插入式CSS,如果存在就先執(zhí)行它,針對(duì)本句的其它CSS就不去管它了;接著檢查網(wǎng)頁(yè)源代碼中 的"STYLE"標(biāo)記,有就執(zhí)行了;接下來(lái)再依次檢查執(zhí)行"@import"導(dǎo)入的內(nèi)部樣式表和 鏈接的外部樣式表。因此,我們完全可以在一個(gè)網(wǎng)頁(yè)中同時(shí)調(diào)用CSS的多種引入方式。 



2、快速創(chuàng)建CSS外連式文件 



對(duì) 于一個(gè)初接觸CSS的網(wǎng)頁(yè)設(shè)計(jì)人員來(lái)講,要用寫(xiě)字板之類的編輯器,去創(chuàng)建一個(gè)CSS外連式文件是相當(dāng)困難的。由于Dreamweaver對(duì)CSS支持的很 好,用它來(lái)幫助就輕松多了。具體可以這樣操作:首先在紙上寫(xiě)好在網(wǎng)站的網(wǎng)頁(yè)中可能要用到的格名稱,然后在Dreamweaver的編輯窗中調(diào)出CSS面 板,一個(gè)一個(gè)地定義,并在一個(gè)空白頁(yè)上適當(dāng)?shù)貙?xiě)一點(diǎn)相關(guān)內(nèi)容,邊定義邊試用,效果不滿意,立即修改;全部定義好后,再用記事本創(chuàng)建一個(gè)空的CSS外連式文 件,把在〈head〉與〈/head〉之間的那段定義好的CSS復(fù)制到CSS文件中去,就大功告成了。 



3、讓背景圖案靜止不動(dòng) 



當(dāng) 網(wǎng)頁(yè)不能在一屏全部顯示時(shí),我們往往借助于水平滾動(dòng)條和豎直滾動(dòng)條來(lái)瀏覽屏幕以外的內(nèi)容,移動(dòng)滾動(dòng)條時(shí)一般圖象和文字是一起移動(dòng)的,那么我們有沒(méi)有辦法使 背景圖象不隨文字一起“滾動(dòng)”呢?利用CSS就可以實(shí)現(xiàn)這樣的目的,我們只要把下面這段源代碼直接放在網(wǎng)頁(yè)的與標(biāo)簽之間就可以了,其中bg.jpg就是網(wǎng) 頁(yè)中的背景圖象,大家可以把它換成自己需要的背景圖象:



復(fù)制代碼



代碼如下:





〈style type="text/css"〉 

〈!-- 

BODY { background: purple url(bg.jpg); 

background-repeat:repeat-y; 

background-attachment:fixed 



--〉 

〈/style〉





4、讓網(wǎng)頁(yè)自動(dòng)進(jìn)行“首行縮進(jìn)” 



用 DreamWeaver來(lái)設(shè)計(jì)網(wǎng)頁(yè)的用戶知道,在DreamWeaver中輸入空格不是那么的方便,我們可以利用css來(lái)設(shè)計(jì)“首行縮進(jìn)”功能來(lái)彌補(bǔ)這個(gè) 缺憾。打開(kāi)DreamWeaver的設(shè)計(jì)界面,在該界面中找到CSS的屬性定義對(duì)話框(Style Definition for .style1),在該對(duì)話框的“Block”標(biāo)簽下的“text-indent”屬性定義設(shè)置項(xiàng)中來(lái)設(shè)置“首行縮進(jìn)”功能,在這里要注意的是,所謂“首 行”是指每段內(nèi)容的第一行,也就是直接按回車(chē)鍵就形成了一個(gè)新的段落??s進(jìn)最好以“em”(字符)為單位,比如:漢字編排要求每段開(kāi)始縮進(jìn)兩個(gè)漢字,設(shè)置 好的CSS如下所示:



復(fù)制代碼



代碼如下:





〈style type="text/css"〉 

〈!-- 

.style1 { text-indent: 2em} 

--〉 

〈/style〉





5、巧用css來(lái)設(shè)定文字的背景 



在 DreamWeaver中,如果我們需要給文字加上不同的背景顏色時(shí),操作上很簡(jiǎn)單,只要用鼠標(biāo)單擊屬性面板上的文字顏色按鈕,從彈出的顏色設(shè)置欄中選擇 需要的顏色就可以了。但如果我們要給部分文字加不同的背景色,該怎么操作呢?由于DreamWeaver3中沒(méi)有這方面的功能,但我們可以巧妙利用css 來(lái)實(shí)現(xiàn)這樣的目的。具體操作過(guò)程是,首先我們可以先做一個(gè)定義背景色的CSS,例如給這個(gè)css命名為bjstyle,接著在網(wǎng)頁(yè)中選中需要設(shè)置顏色的文 字,然后在工具欄中單擊一下“bjstyle”就行了。下面就是一個(gè)定義顏色背景的CSS的源代碼:



復(fù)制代碼



代碼如下:





〈style type="text/css"〉 

〈!-- 

.bjstyle { background: #cc00bb} 

--〉 

〈/style〉





6、給指定內(nèi)容加邊框 



在 DreamWeaver中,我們可以利用CSS強(qiáng)大的定義功能來(lái)給某部分內(nèi)容加邊框,定義時(shí)首先打開(kāi)DreamWeaver的設(shè)計(jì)界面,在該界面中找到 CSS的屬性定義對(duì)話框(Style Definition for .style1),該對(duì)話框的“Border”設(shè)置項(xiàng)就是用來(lái)定義指定內(nèi)容邊框線的,其中“top”、“bottom”、“l(fā)eft”、“right”設(shè) 置欄是分別用來(lái)定義指定內(nèi)容四周邊框線的粗細(xì)和顏色的,這些設(shè)置項(xiàng)設(shè)置好后還需要在下面的“Style”中定義線型,否則我們將看不到定義的邊框線,因?yàn)?css默認(rèn)的線型是“none”。下面是一個(gè)定義了上邊框?yàn)椋核{(lán)色細(xì)線;左邊框?yàn)椋壕G色中粗線的CSS源代碼:



復(fù)制代碼



代碼如下:





〈style type="text/css"〉 

〈!-- 

.style1 { border: solid; border-width: thin 0px 0px medium; border-color: #0000FF black black #00FF00} 

--〉 

〈/style〉





7、用樣式表來(lái)控制超級(jí)鏈接的顏色 



如 果你仔細(xì)研究一下超級(jí)鏈接,你就會(huì)發(fā)現(xiàn),瀏覽器處理超級(jí)鏈接的默認(rèn)方式是,對(duì)于目前還沒(méi)有訪問(wèn)過(guò)的超級(jí)鏈接是用藍(lán)色且?guī)в邢聞澗€的文字來(lái)顯示的,對(duì)于已經(jīng) 訪問(wèn)過(guò)的超級(jí)鏈接則是用深紫色且?guī)в猩钭仙南聞澗€的文字來(lái)顯示的。這些默認(rèn)的設(shè)置顏色看得時(shí)間,可能就產(chǎn)生厭倦之感,并且很有可能與自己網(wǎng)頁(yè)的背景顏色 不協(xié)調(diào)。因此我們完全可以按照自己的視覺(jué)要求,來(lái)自由更改超級(jí)鏈接的顯示顏色,讓它更能體現(xiàn)自己的風(fēng)格。下面筆者就來(lái)介紹一段修改超級(jí)鏈接顯示顏色的源代 碼,代碼如下: 



我們可以把這段源代碼添加在HTML文件的……之間,它可以對(duì)對(duì)本網(wǎng)頁(yè)中的任何一個(gè)超級(jí)鏈接都起作用,其中這段代碼中的: 



A:link {text-decoration: none; color:blue}是說(shuō)明了超級(jí)鏈接還沒(méi)有被訪問(wèn),它沒(méi)有下劃線,顏色為藍(lán)色。 



A:visited { color:red; text-decoration:line-through }說(shuō)明了超級(jí)鏈接被訪問(wèn)后,它的顏色變成了紅色,有了一根刪除線。 



A:active { color:white; text-decoration:underline }說(shuō)明超級(jí)鏈接處于活動(dòng)狀態(tài)的時(shí)候,它的顏色變成了白色,有了下劃線。 



A:hover {text-decoration:none;color:#FF0000;background-color:black}說(shuō)明鼠標(biāo)移動(dòng)到超級(jí)鏈接后,它沒(méi)有下劃線,文字顏色變成了黃色,背景顏色是黑色。 



新建一個(gè)前端學(xué)習(xí)qun438905713,在群里大多數(shù)都是零基礎(chǔ)學(xué)習(xí)者,大家相互幫助,相互解答,并且還準(zhǔn)備很多學(xué)習(xí)資料,歡迎零基礎(chǔ)的小伙伴來(lái)一起交流。



根據(jù)上面的解釋,我們可以把超級(jí)鏈接在各種狀態(tài)下的顯示顏色修改成自己喜歡的那種,以便能更好地展示自己的個(gè)性。 



8、給選中文字加背景圖像 



在 DreamWeaver中,我們同樣可以給指定文字加上背景圖象,其操作過(guò)程與給指定文字加背景色操作類似,只不過(guò)是把選擇背景顏色換成選擇加載的背景圖 象就是了。其具體操作過(guò)程是,首先我們可以先做一個(gè)定義背景色的CSS,例如給這個(gè)css命名為txstyle,接著在網(wǎng)頁(yè)中選中需要設(shè)置顏色的文字,然 后在工具欄中單擊一下“txstyle”就行了。下面就是一個(gè)定義背景圖象的CSS的源代碼(其中test.gif就是所加載的背景圖象):



復(fù)制代碼



代碼如下:





〈style type="text/css"〉 

〈!-- 

.txbgstyle { background-image: url(test.gif)} 

--〉 

〈/style〉

————————————————

版權(quán)聲明:本文為CSDN博主「html基礎(chǔ)教程」的原創(chuàng)文章,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。

原文鏈接:https://blog.csdn.net/html168/article/details/104525011

數(shù)字工業(yè)導(dǎo)購(gòu)場(chǎng)景設(shè)計(jì) —— 工業(yè)品牌PC 3.0升級(jí)

資深UI設(shè)計(jì)者

2019下半年,阿里巴巴旗下B2B業(yè)務(wù)平臺(tái)1688官宣了全新的戰(zhàn)略升級(jí)目標(biāo):針對(duì)工業(yè)領(lǐng)域進(jìn)行全面升級(jí)支撐,堅(jiān)持“品牌正品、品質(zhì)服務(wù)”,聚焦在內(nèi)容、服務(wù)和用戶上,致力于打造需求驅(qū)動(dòng)的C2M新模式。重塑市場(chǎng)格局,加速制造業(yè)流通數(shù)字化升級(jí)。

伴隨著業(yè)務(wù)的整體升級(jí),工業(yè)品牌PC首頁(yè)作為買(mǎi)賣(mài)家感知業(yè)務(wù)價(jià)值的門(mén)面和流量承接的關(guān)鍵場(chǎng)景,需要同步升級(jí)才能更好的滿足買(mǎi)家需求,提升買(mǎi)家體驗(yàn)。


三大升級(jí)目標(biāo)


1、 提升內(nèi)容與買(mǎi)家匹配精準(zhǔn)度:從舊版的數(shù)據(jù)分析來(lái)看,搜索和導(dǎo)航欄UV占比超過(guò)70%,其他區(qū)塊尤其二屏及以下點(diǎn)擊率很低,說(shuō)明市場(chǎng)大部分的內(nèi)容對(duì)用戶沒(méi)有吸引力,需要為用戶推薦更豐富、更精準(zhǔn)的內(nèi)容才能把用戶留下。 


2、 提升內(nèi)容框架合理性:舊版場(chǎng)景框架結(jié)構(gòu)較為混亂,內(nèi)容組合自由度過(guò)高,采購(gòu)鏈路不清晰導(dǎo)致用戶體驗(yàn)不佳。且隨著內(nèi)容的更新,舊的框架和新的內(nèi)容也無(wú)法匹配,需要升級(jí)框架使采購(gòu)鏈路清晰化,提升用戶體驗(yàn)。 


3、 提升工業(yè)品牌業(yè)務(wù)認(rèn)知:隨著業(yè)務(wù)打法的升級(jí),工業(yè)品牌的核心理念也進(jìn)行了升級(jí),新版的工業(yè)品牌市場(chǎng)需要提升用戶對(duì)平臺(tái)價(jià)值的認(rèn)知,樹(shù)立品牌正品的心智。


升級(jí)策略 


一、 圍繞買(mǎi)家分層升級(jí)內(nèi)容,提升內(nèi)容與買(mǎi)家匹配精準(zhǔn)度 


定義用戶感興趣的內(nèi)容,從買(mǎi)家分層做起。我們沿著圍繞買(mǎi)家身份進(jìn)行個(gè)性化導(dǎo)購(gòu)場(chǎng)景推薦的思路,以用研提供的買(mǎi)家核身數(shù)據(jù)資料為基礎(chǔ),再結(jié)合運(yùn)營(yíng)提供的經(jīng)驗(yàn),提煉出不同身份的用戶畫(huà)像,抽象出他們的采購(gòu)特性。

 

然后新增了一個(gè)專門(mén)的個(gè)性化身份場(chǎng)景模塊,進(jìn)行有針對(duì)性的商品、商家、工具推薦,實(shí)現(xiàn)人、貨、場(chǎng)的個(gè)性化匹配。

除了新增的個(gè)性化身份場(chǎng)景外,首屏新增了三個(gè)固定營(yíng)銷(xiāo)位,聚焦在典型買(mǎi)家的普遍訴求上:新人活動(dòng)、金融活動(dòng)和服務(wù)(物流/發(fā)票)專場(chǎng),打造以貿(mào)易商/電商為核心,門(mén)店/企業(yè)自用為輔助客群的營(yíng)銷(xiāo)+工具一體化流量圈。同時(shí)新增了低價(jià)場(chǎng)景,以日為單位,折扣幅度更大的“每日特惠”,用低價(jià)的硬通貨提升用戶粘性促進(jìn)轉(zhuǎn)化,強(qiáng)化用戶對(duì)工業(yè)品牌的認(rèn)知。


二、 打造營(yíng)銷(xiāo)+工具扁平陣地,從內(nèi)容框架升級(jí)提升體驗(yàn) 


1、 采購(gòu)鏈路清晰化


定義每一屏用戶的核心訴求,提供有效的、符合用戶預(yù)期的對(duì)應(yīng)內(nèi)容

2、 簡(jiǎn)化容器形式:突出內(nèi)容降低閱讀成本

以首屏設(shè)計(jì)為例,以不同底色分隔區(qū)塊,省略所有不必要的間距分隔,使首屏的整體性更強(qiáng),形式更緊湊聚焦。


三、 營(yíng)造「數(shù)字工業(yè)」氛圍,提升用戶對(duì)市場(chǎng)感知,塑造品牌正品心智 


導(dǎo)購(gòu)場(chǎng)景里的品牌打造,核心價(jià)值在于強(qiáng)化市場(chǎng)形象,讓用戶感知到平臺(tái)價(jià)值,認(rèn)知平臺(tái)特性。工業(yè)品的電商網(wǎng)站那么多,除了內(nèi)容層,表現(xiàn)層我們也需要和其他網(wǎng)站有顯著區(qū)分,具有自己的“個(gè)性”,給用戶不一樣的體感。 


所謂“個(gè)性”即是品牌定位。我們從工業(yè)品牌的平臺(tái)定位出發(fā),聚焦業(yè)務(wù)本質(zhì)的核心理念和價(jià)值優(yōu)勢(shì)上,再結(jié)合用戶視角的感知傾向,最后推導(dǎo)出數(shù)字化、工業(yè)感兩個(gè)核心關(guān)鍵詞。然后順著關(guān)鍵詞進(jìn)行具像化發(fā)散,再?gòu)木呦笤刂泻Y選出典型的,抽象的融入到頁(yè)面中落地,從而打造「數(shù)字工業(yè)」的品牌形象。


標(biāo)準(zhǔn)色&ICON


工業(yè)品牌從1.0版本開(kāi)始就一直采用的是黑黃配色,黑灰色取自金屬,黃色則是機(jī)械設(shè)備、工業(yè)產(chǎn)品(如安全帽)上的常用漆色,這兩種顏色是工業(yè)場(chǎng)景中最具代表性、通用性的常見(jiàn)色,容易讓用戶感到熟悉而引起情感共鳴。為了品牌的延續(xù)性,3.0仍然保持了黑黃的主配色,并在此基礎(chǔ)上新增了四種從工業(yè)品行業(yè)場(chǎng)景中提取的重色調(diào)冷色,增加配色上的豐富度和拓展性。ICON設(shè)計(jì)上運(yùn)用粗重的線條,硬朗的方角,塑造沉穩(wěn)、嚴(yán)謹(jǐn)?shù)捏w感。

圖形&動(dòng)效


為了營(yíng)造具有科技感的數(shù)字化氛圍,在設(shè)計(jì)中融入了一些從HUD風(fēng)格中抽取出的元素。如每日特惠模塊中的動(dòng)態(tài)表盤(pán)和標(biāo)注數(shù)據(jù)變化,會(huì)呼吸的閃爍button和hover狀態(tài)下出現(xiàn)的定位框。前者表達(dá)了數(shù)字化的概念的同時(shí)強(qiáng)調(diào)了折扣幅度、板塊特性,后者則算是操作時(shí)出現(xiàn)的小彩蛋。

立體組貨場(chǎng)景導(dǎo)購(gòu):3D化的場(chǎng)景還原導(dǎo)購(gòu),直觀的體現(xiàn)線下生產(chǎn)場(chǎng)景的線上“數(shù)字化”的概念,不僅易讓用戶產(chǎn)生代入感,也增加了頁(yè)面導(dǎo)購(gòu)專業(yè)度與視覺(jué)豐富度。

升級(jí)后整體數(shù)據(jù)提升明顯


結(jié)語(yǔ)


此次PC整體升級(jí),根據(jù)買(mǎi)家分層新增了更精準(zhǔn)匹配的場(chǎng)景推薦,優(yōu)化了內(nèi)容框架,營(yíng)造了數(shù)字工業(yè)的氛圍來(lái)塑造具有平臺(tái)特性的市場(chǎng)形象。當(dāng)然在項(xiàng)目的過(guò)程中,也因?yàn)轫?xiàng)目周期內(nèi)的一些局限性,讓產(chǎn)品還有很多優(yōu)化完善的空間,后續(xù)仍需繼續(xù)挖掘買(mǎi)家訴求,通過(guò)不斷的探索和創(chuàng)新,提升買(mǎi)家體驗(yàn)。

文章來(lái)源:站酷    作者:CBU設(shè)計(jì) 龍奕柯

三步法 - 助力精準(zhǔn)提取設(shè)計(jì)思路

資深UI設(shè)計(jì)者

設(shè)計(jì)思路提取三步法

文章來(lái)源:站酷    作者:設(shè)獵派


這個(gè)網(wǎng)站能猜出你最喜歡的配色組合!

資深UI設(shè)計(jì)者

本文要介紹的「Palettable」是一個(gè)線上配色工具,Palettable 通過(guò)互動(dòng)方式協(xié)助使用者找出最合適的色彩組合,開(kāi)啟網(wǎng)站后會(huì)先隨機(jī)顯示顏色,使用者可點(diǎn)選喜歡、不喜歡(或是使用快捷鍵)重新顯示顏色或?qū)㈩伾潭ㄔ陧?yè)面中,最后就能得出五個(gè)搭配好的顏色組合。

依照說(shuō)明,Palettable 收錄數(shù)百萬(wàn)設(shè)計(jì)師的知識(shí)結(jié)晶,這些顏色可以協(xié)助我們產(chǎn)生漂亮的調(diào)色盤(pán),利用控制選項(xiàng)亦可個(gè)別調(diào)整每個(gè)顏色,最后匯出帶有色碼的PNG 圖片或固定網(wǎng)址。

Palettable

網(wǎng)站鏈接:https://www.palettable.io/

使用教學(xué)

開(kāi)啟Palettable 后會(huì)隨機(jī)顯示一個(gè)顏色,可點(diǎn)選下方的喜歡或不喜歡(快捷鍵為L(zhǎng) 和D),喜歡會(huì)將顏色固定并開(kāi)始選擇下一個(gè)顏色,不喜歡就會(huì)繼續(xù)演算其他顏色。

每個(gè)顏色中間會(huì)有HEX 色碼,點(diǎn)選下方的設(shè)定選項(xiàng)會(huì)出現(xiàn)調(diào)色盤(pán),可以更直覺(jué)選擇你要的顏色。

點(diǎn)選喜歡后前一個(gè)顏色會(huì)被固定,接著就繼續(xù)選下一個(gè)顏色。

在我十分鐘的使用經(jīng)驗(yàn),重復(fù)幾次不同的配色組合,發(fā)現(xiàn)Palettable 會(huì)隨著使用者喜歡的顏色而選擇更為貼近、可互相搭配且不重復(fù)的色彩,這部份相較于其他只能隨機(jī)選色的服務(wù)來(lái)說(shuō)應(yīng)該更有優(yōu)勢(shì)。

持續(xù)重復(fù)到第五個(gè)顏色,Palettable會(huì)跳出最多只有5個(gè)顏色的提示訊息,點(diǎn)選「Export」匯出結(jié)果。

Palettable 支援匯出為固定網(wǎng)址(會(huì)帶有你剛才選定的五個(gè)顏色組合)或是輸出為PNG 格式,如果你想把顏色組合保存下來(lái),儲(chǔ)存為圖片會(huì)更易于整理和使用。

下圖就是我透過(guò)Palettable 建立的配色組合,每個(gè)顏色會(huì)有預(yù)覽,下方帶有HEX 色碼。

值得一試的三個(gè)理由:

  • 透過(guò)互動(dòng)方式協(xié)助使用者找出最合適的色彩組合
  • 利用使用者選擇的顏色,計(jì)算出更貼近、可互相搭配的色彩
  • 匯出為帶有色碼PNG 圖片格式,或是產(chǎn)生固定網(wǎng)址

文章來(lái)源:優(yōu)設(shè)    作者:Pseric

為什么2020年初爆火的新擬物化設(shè)計(jì),完全無(wú)法落地使用?

資深UI設(shè)計(jì)者

新擬態(tài)設(shè)計(jì)(Neumorphism UI)是 2020 年 UI 設(shè)計(jì)的主要趨勢(shì)之一,你可以在 dribbble 上看到很多作品,新擬態(tài)是基于New+Skeuomorphism  英文單詞的拼寫(xiě)。它是一種使用對(duì)象陰影的模糊、角度和強(qiáng)度來(lái)突顯出對(duì)象的樣式。由于其柔和的陰影和整體的外觀,使該設(shè)計(jì)看起來(lái)更加的逼真、未來(lái)、現(xiàn)代、真實(shí)、有吸引力。

但是老實(shí)說(shuō),這不是最實(shí)用的設(shè)計(jì)。嘗試設(shè)計(jì)和上線以「新擬態(tài)」為整體調(diào)性的產(chǎn)品,很有可能讓所有人失望,包括你們的同事、用戶和可訪問(wèn)性用戶(目前有 5700 萬(wàn)美國(guó)人患有某種程度的殘疾。在上網(wǎng)的用戶中,有 54% 的成年人是殘障人士,來(lái)源于:W3.org)。

根據(jù) W3 的說(shuō)法,web 和移動(dòng)端的可訪問(wèn)性包括影響訪問(wèn)的所有障礙,包含:

  • 聽(tīng)覺(jué)的
  • 認(rèn)知的
  • 神經(jīng)學(xué)
  • 物理的
  • 語(yǔ)言/說(shuō)話能力
  • 視覺(jué)的

僅新擬態(tài)而言并不支持:視覺(jué)、認(rèn)知、物理方面設(shè)計(jì)。

讓我們深入地討論為什么新擬態(tài) UI 和 可訪問(wèn)性是無(wú)法共存的。

免責(zé)聲明:我不是可訪問(wèn)性和新擬態(tài)方面的設(shè)計(jì)專家,本文旨在分享一些有關(guān)新擬態(tài)的一些想法。下面使用的 dribbble 作品僅供參考,以突出我在此問(wèn)題上的觀點(diǎn)。沒(méi)有一絲評(píng)價(jià)、嘲笑、不尊重以下設(shè)計(jì)師的意思,如果你的設(shè)計(jì)在下面展示了,并且你希望我盡快刪除,請(qǐng)及時(shí)聯(lián)系我。

視覺(jué)

新擬態(tài)對(duì)視力低下、失明、色盲的用戶來(lái)說(shuō),可辨識(shí)性較差。

△ https://dribbble.com/shots/10006635-Neumorphic-Rebound-of-Nomad-iOS-UI-Kit

當(dāng)設(shè)計(jì)中帶有重要 CTA 按鈕時(shí),你經(jīng)??紤]并注意使它重點(diǎn)突出,并且在頁(yè)面上容易被識(shí)別閱讀。但是,當(dāng)使用新擬態(tài)的設(shè)計(jì)風(fēng)格時(shí),沒(méi)有諸如對(duì)比度之類的東西,因?yàn)榘粹o的材質(zhì)與背景是相同的,唯一將它們分開(kāi)的是角度和各種柔和的陰影。

△ https://dribbble.com/shots/9393020-Mi-Remote-Control-Mobile-app

根據(jù) W3.org 關(guān)于移動(dòng)端可訪問(wèn)性的描述:

與臺(tái)式機(jī)/筆記本電腦設(shè)備相比,移動(dòng)設(shè)備更可能用于各種環(huán)境中,包括戶外。在戶外,陽(yáng)光或其他強(qiáng)光源下更可能產(chǎn)生眩光,這種情況提高了對(duì)所有用戶使用良好對(duì)比度的重要性,并可能加劇視力低下的用戶在移動(dòng)設(shè)備上訪問(wèn)對(duì)比度差的內(nèi)容的挑戰(zhàn)性。

與對(duì)比度問(wèn)題相關(guān)的 WCAG 2.0 成功標(biāo)準(zhǔn)是(原文地址:https://w3c.github.io/WCAG21-zh/#contrast-minimum):

  • 1.4.3條:對(duì)比度(最小值)(AA級(jí)),要求對(duì)比度至少為 4.5:1(大號(hào)文本以及大文本圖像至少保持 3:1)。
  • 1.4.6條:對(duì)比度(增強(qiáng))(AAA級(jí)),要求對(duì)比度至少為 7:1(大號(hào)文本以及大文本圖像至少保持 4.5:1)。

認(rèn)知

新擬態(tài)讓用戶思考。

△ https://dribbble.com/shots/9592062-Neumorphism-Smart-Home

一般來(lái)說(shuō),帶有陰影的元素通常比沒(méi)有陰影的視覺(jué)上更加突出。但是,使用新擬態(tài)設(shè)計(jì)時(shí),大多數(shù)元素都會(huì)漂浮并脫穎而出,在一個(gè)屏幕上互相競(jìng)爭(zhēng),用戶很難輕易理解頁(yè)面中的視覺(jué)層次和信息層級(jí)關(guān)系,這會(huì)導(dǎo)致界面缺少適當(dāng)?shù)慕裹c(diǎn),從而在眼動(dòng)追蹤中造成混亂。

界面上缺少信息層級(jí)關(guān)系的結(jié)果,會(huì)對(duì)用戶的決策過(guò)程以及他們的思考過(guò)程產(chǎn)生重大的影響。因此,如存在多個(gè)可操作的內(nèi)容,但是信息層級(jí),重點(diǎn)不突出,這會(huì)讓用戶在當(dāng)前的流程或頁(yè)面上產(chǎn)生困惑,很難理解正在發(fā)生的事情。從而可能導(dǎo)致錯(cuò)誤的判斷和誤操作,好的 UI/UX 不需要讓用戶思考。

認(rèn)知和學(xué)習(xí)障礙影響人們處理信息的方式。例如,它們可以影響人們的感知、記憶、語(yǔ)言、注意力、解決問(wèn)題和理解力。類別和條件的術(shù)語(yǔ)各不相同,包括智力殘疾、發(fā)育障礙、注意缺陷多動(dòng)障礙(ADHD)、自閉癥、癡呆癥、誦讀障礙等。

△ https://dribbble.com/shots/9916835-Neumorphism-Smart-Home-app

物理

新擬態(tài)會(huì)造成混亂:

  • 我可以點(diǎn)擊嗎?
  • 選擇了什么?
  • 不是什么?
  • 這是可點(diǎn)擊的嗎?
  • 還是不是?

對(duì)象的階段由內(nèi)部/外部陰影決定和標(biāo)識(shí)。由于新擬態(tài)圍繞著各種陰影色調(diào)和角度變化,因此用戶不禁要問(wèn),可點(diǎn)擊與不可點(diǎn)擊之間的界限在哪里。

△ https://dribbble.com/shots/9938821-Smart-home-app

每個(gè)使用新擬態(tài)的產(chǎn)品都可以根據(jù)其功能和要求有自己的 UI 設(shè)計(jì)規(guī)范,但是由于陰影、角度和浮動(dòng)水平的不同,由于缺乏一致性,迷失了方向的可操作項(xiàng),「新擬態(tài)」可能會(huì)給用戶帶來(lái)麻煩,最終為殘疾用戶造成身體障礙。

觸發(fā)可操作性的元素應(yīng)該足夠清晰,以便與不可操作的元素(內(nèi)容、狀態(tài)信息等)明確區(qū)分。提供元素可操作的明確指示與具有可操作元素(如按鈕或鏈接)的 web 和本機(jī)移動(dòng)應(yīng)用程序相關(guān),尤其是在交互模式中,可操作元素通常以視覺(jué)方式檢測(cè)(觸摸和鼠標(biāo)使用)。交互元素還必須由依賴于編程確定的可訪問(wèn)名稱的用戶(例如屏幕閱讀器用戶)檢測(cè)到。

△ https://dribbble.com/shots/9838619-Music-Player-Neumorphism-Rebound-shot

從 dribbble 開(kāi)始的新擬態(tài)的設(shè)計(jì)趨勢(shì),應(yīng)該要在追隨前認(rèn)真地思考,是否適用?這是一個(gè)問(wèn)題。

設(shè)計(jì)師可以自由地實(shí)踐和探索他們傾向于哪種趨勢(shì)或風(fēng)格……我只是在這里展示和解釋為什么「新擬態(tài)」和「可訪問(wèn)性」不能并存。我也不是來(lái)阻止你練習(xí)你的設(shè)計(jì)技巧(如果有的話,我鼓勵(lì)每個(gè)人練習(xí)他們的技巧和探索他們的想法,但希望,考慮它可能對(duì)殘疾用戶的影響以及特殊場(chǎng)景下的實(shí)用性的思考)。

不過(guò),我之前在另一篇文章中說(shuō)過(guò),我會(huì)再說(shuō)一次:現(xiàn)在是 2020 年,作為一個(gè)設(shè)計(jì)師,我認(rèn)為我們必須重新評(píng)估我們?cè)谠O(shè)計(jì)實(shí)際產(chǎn)品時(shí)的設(shè)計(jì)方式。我們不能為所有人設(shè)計(jì),但要排除殘疾用戶。在可訪問(wèn)性和使所有數(shù)字產(chǎn)品都可訪問(wèn)方面,我們還有很長(zhǎng)的路要走,但是它必須要在某一個(gè)地方開(kāi)始。例如,它可以從我們把新擬態(tài)拋在腦后開(kāi)始,而從那時(shí)起專注于開(kāi)發(fā)一種在美學(xué)上令人愉悅但又實(shí)用、現(xiàn)實(shí)的設(shè)計(jì)。謝謝。

文字來(lái)源:優(yōu)設(shè)    作者:UX Talk

「設(shè)計(jì)系統(tǒng)」 構(gòu)建指南

資深UI設(shè)計(jì)者

這篇文章來(lái)自于 Invision 出品的書(shū)籍,圍繞規(guī)劃、設(shè)計(jì)、構(gòu)建和實(shí)現(xiàn)設(shè)計(jì)系統(tǒng)的實(shí)踐經(jīng)歷來(lái)指導(dǎo)讀者,其中包含了經(jīng)驗(yàn)豐富專家的真知灼見(jiàn)和一手經(jīng)驗(yàn)。我很喜歡,也分享給大家,推薦閱讀。這是一個(gè)系列,一共有 7 章,感興趣的話,持續(xù)關(guān)注吧。

20 世紀(jì) 60 年代,計(jì)算機(jī)硬件技術(shù)的升級(jí)開(kāi)始超越軟件發(fā)展的速度。計(jì)算機(jī)的處理速度變得越來(lái)越快,價(jià)格也越來(lái)越便宜,但計(jì)算機(jī)軟件開(kāi)發(fā)仍然處于緩慢、難以維護(hù)的境地,并且還很容易出錯(cuò)。兩者之間的差距以及解決這個(gè)問(wèn)題的困境被稱之為「軟件危機(jī)」。

在 1968 年的北約軟件工程會(huì)議上,道格拉斯·麥克羅伊(Douglas McIlroy)提出了基于組件開(kāi)發(fā)有可能是解決「軟件危機(jī)」的方法之一?;诮M件開(kāi)發(fā)是一種通過(guò)復(fù)用代碼來(lái)提高編程潛力的方法,該方法能幫助編程工作更、更易于擴(kuò)展。這樣做既能減少編程工作量又能提升軟件開(kāi)發(fā)的速度,讓軟件更好地運(yùn)用現(xiàn)代計(jì)算機(jī)的力量。

在 50 年后的今天,我們又面臨著類似的挑戰(zhàn),只不過(guò)這一次是在設(shè)計(jì)領(lǐng)域。在 UI 設(shè)計(jì)中,設(shè)計(jì)的角色是在為特定需求量身定做解決方案,所以很難去基于整個(gè)應(yīng)用進(jìn)行擴(kuò)展。

你有沒(méi)有走查過(guò)你輸出的界面,發(fā)現(xiàn)自己使用了幾十種類似的藍(lán)色,或者同一個(gè)按鈕不同的用法,將這些樣式組合對(duì)應(yīng)到你設(shè)計(jì)的每一個(gè) UI 界面,就會(huì)意識(shí)到一套不成體系的設(shè)計(jì)是多么的難以維護(hù)。

△ 一份 UI 樣式走查收集的成果,里面羅列的十幾種類似的按鈕樣式說(shuō)明之前團(tuán)隊(duì)挖的坑有多深。

在這種狀態(tài)下,設(shè)計(jì)要跟上開(kāi)發(fā)的速度,公司可以選擇做以下三件事:

  • 雇更多的人
  • 提高設(shè)計(jì)速度
  • 找到一個(gè)適用于多個(gè)問(wèn)題的解決方案

通過(guò)復(fù)用設(shè)計(jì),設(shè)計(jì)系統(tǒng)能夠幫助團(tuán)隊(duì)更好、更快地構(gòu)建產(chǎn)品——復(fù)用性使規(guī)范成為可能。這是設(shè)計(jì)系統(tǒng)的核心和價(jià)值。一個(gè)設(shè)計(jì)系統(tǒng)是一個(gè)可復(fù)用組件的合集,由清晰的規(guī)范作為指導(dǎo),組合在一起構(gòu)建成各種的應(yīng)用程序。

50 多年來(lái),工程師們一直在遵循著這個(gè)理念執(zhí)行工作。現(xiàn)在是時(shí)候讓設(shè)計(jì)充分發(fā)揮其潛力加入他們了。

用系統(tǒng)思維擴(kuò)展設(shè)計(jì)

你可能已經(jīng)清楚地意識(shí)到,設(shè)計(jì)系統(tǒng)已經(jīng)成為當(dāng)今軟件行業(yè)的一個(gè)熱門(mén)話題,并且理由也很充分。很多企業(yè)投資設(shè)計(jì)系統(tǒng),因?yàn)樗麄冋J(rèn)識(shí)到產(chǎn)品體驗(yàn)?zāi)軌驇?lái)競(jìng)爭(zhēng)優(yōu)勢(shì),不僅能吸引和留住客戶,更降低產(chǎn)品學(xué)習(xí)成本。

在重視設(shè)計(jì)系統(tǒng)的公司內(nèi)部,通常能看見(jiàn)這種情況:

  • 設(shè)計(jì)團(tuán)隊(duì)不斷壯大。
  • 設(shè)計(jì)師分布在整個(gè)公司的團(tuán)隊(duì)中,可能在多個(gè)部門(mén)。
  • 設(shè)計(jì)在整個(gè)公司平臺(tái)上的各個(gè)產(chǎn)品中都起著關(guān)鍵作用。

如果你是設(shè)計(jì)師,那么前面所說(shuō)對(duì)設(shè)計(jì)的投資聽(tīng)起來(lái)可能會(huì)令你很興奮,但其實(shí)也帶來(lái)很多挑戰(zhàn)。當(dāng)一個(gè)應(yīng)用由不同的團(tuán)隊(duì)負(fù)責(zé)迭代各自模塊的時(shí)候,你將如何跨平臺(tái)設(shè)計(jì)一致的 UI?又如何使所有團(tuán)隊(duì)能夠進(jìn)行快速迭代?當(dāng)團(tuán)隊(duì)的設(shè)計(jì)師設(shè)計(jì)出新的獨(dú)立樣式時(shí),你又將如何處理這種不可避免的設(shè)計(jì)需求?

要了解如何應(yīng)對(duì)上述的挑戰(zhàn),我們要先了解什么是設(shè)計(jì)系統(tǒng)。設(shè)計(jì)系統(tǒng)將個(gè)體和整體兩個(gè)概念各自的優(yōu)點(diǎn)結(jié)合在一起。

1. 標(biāo)準(zhǔn)

擁有 MAC 用戶界面的技術(shù)知識(shí)是產(chǎn)品設(shè)計(jì)的關(guān)鍵因素,但了解用戶界面背后的理論,才能夠幫助你創(chuàng)造出色的產(chǎn)品。——蘋(píng)果人機(jī)交互指南

為了設(shè)計(jì)卓越的用戶體驗(yàn),不僅要了解設(shè)計(jì)系統(tǒng)背后的內(nèi)容,還要了解其設(shè)計(jì)的原因。我們一般會(huì)通過(guò)建立和遵守標(biāo)準(zhǔn)來(lái)達(dá)成共識(shí),這樣做能消除主觀性和歧義性,保證產(chǎn)品團(tuán)隊(duì)內(nèi)部不會(huì)出現(xiàn)摩擦和混亂。

這套標(biāo)準(zhǔn)的內(nèi)容涵蓋了設(shè)計(jì)和開(kāi)發(fā)。例如對(duì)命名約定、無(wú)障礙標(biāo)準(zhǔn)和文件結(jié)構(gòu)等等,幫助團(tuán)隊(duì)達(dá)成共識(shí),減少出錯(cuò)。

視覺(jué)語(yǔ)言是設(shè)計(jì)標(biāo)準(zhǔn)的核心部分。定義顏色、形狀、類型、圖標(biāo)、布局和動(dòng)效的樣式和用法對(duì)于創(chuàng)建品牌一致的用戶體驗(yàn)至關(guān)重要。系統(tǒng)中的每個(gè)組件都包含這些元素,它們?cè)诒磉_(dá)品牌特性中扮演著不可或缺的角色。

沒(méi)有標(biāo)準(zhǔn),決策時(shí)就會(huì)無(wú)據(jù)可依。這不僅不能擴(kuò)展設(shè)計(jì),還會(huì)造成復(fù)雜、差勁的用戶體驗(yàn)。

超越平臺(tái)

視覺(jué)語(yǔ)言可以不局限于單一平臺(tái),可以在 Web,iOS,Android 和其他平臺(tái)上延續(xù)。將規(guī)范文檔展示在設(shè)計(jì)系統(tǒng)網(wǎng)站的醒目位置,能夠幫助系統(tǒng)開(kāi)發(fā)者了解組件的樣式和交互模式。例如,Google 的 Material Design 就深入到其產(chǎn)品視覺(jué)語(yǔ)言的各個(gè)層面。

2. 組件

組件是系統(tǒng)中復(fù)用代碼的一部分,它們充當(dāng)應(yīng)用程序界面的基礎(chǔ)。組件的復(fù)雜性各不相同。將組件簡(jiǎn)化為單個(gè)功能(如按鈕或下拉菜單)可以增加其靈活性,使其更易于復(fù)用。復(fù)雜的組件,如特定類型數(shù)據(jù)的圖表,可以很好地滿足其應(yīng)用場(chǎng)景,但是這種復(fù)雜性限制它的使用場(chǎng)景數(shù)量。組件的復(fù)用性越高,需要維護(hù)的次數(shù)就越少,規(guī)模也就越簡(jiǎn)單。

基于組件的開(kāi)發(fā)通過(guò)復(fù)用代碼來(lái)減少技術(shù)開(kāi)銷(xiāo)。建立標(biāo)準(zhǔn)規(guī)范了這些組件的用途、樣式和用法。兩者結(jié)合在一起,就相當(dāng)于為你的產(chǎn)品團(tuán)隊(duì)配備了一個(gè)清晰的系統(tǒng),讓他們了解到為什么和怎么做。

設(shè)計(jì)系統(tǒng)的價(jià)值

讓我們?cè)敿?xì)看看設(shè)計(jì)系統(tǒng)如何幫助你解決一直以來(lái)的痛苦。

1. 擴(kuò)展式設(shè)計(jì)

隨著團(tuán)隊(duì)的成長(zhǎng),設(shè)計(jì)師通常會(huì)將注意力集中在應(yīng)用程序的獨(dú)立功能區(qū)域,如搜索和發(fā)現(xiàn)、帳戶管理等。這就會(huì)導(dǎo)致設(shè)計(jì)碎片化,就像是一座設(shè)計(jì)的巴別塔,每個(gè)設(shè)計(jì)師都將他們的設(shè)計(jì)語(yǔ)言往上添。當(dāng)設(shè)計(jì)師單獨(dú)而不是系統(tǒng)地去解決問(wèn)題時(shí),就會(huì)發(fā)生這種情況。

沒(méi)有通用設(shè)計(jì)語(yǔ)言統(tǒng)一產(chǎn)品和設(shè)計(jì),用戶體驗(yàn)就會(huì)開(kāi)始崩潰。當(dāng)缺乏設(shè)計(jì)規(guī)范時(shí),設(shè)計(jì)討論就變得毫無(wú)用處。為了使團(tuán)隊(duì)內(nèi)部保持一致,必須要有一個(gè)共享的來(lái)源——可供參考的官方樣式庫(kù)。

大多數(shù)情況下的樣式庫(kù)都是靜態(tài)的內(nèi)容,例如設(shè)計(jì)模版。但是靜態(tài)的參考幾乎立刻就會(huì)過(guò)時(shí)。這就是為什么有的團(tuán)隊(duì)會(huì)建造像 Shopify’s Polaris 站點(diǎn)這樣的網(wǎng)站——一個(gè)設(shè)計(jì)系統(tǒng)站點(diǎn),用該設(shè)計(jì)系統(tǒng)構(gòu)建而成,記錄系統(tǒng)的所有方面,包括組件、指南和交互最佳使用場(chǎng)景。因?yàn)樗桥c系統(tǒng)一起構(gòu)建的,所以它能夠保持其永遠(yuǎn)是的。

對(duì)于產(chǎn)品團(tuán)隊(duì)而言,內(nèi)部設(shè)計(jì)系統(tǒng)站點(diǎn)是最佳、最易訪問(wèn)的共享來(lái)源。它提供了一個(gè)引力,使團(tuán)隊(duì)成員保持一致和同步。

2. 管理你的債務(wù)

隨著應(yīng)用程序和團(tuán)隊(duì)的時(shí)間積累,會(huì)慢慢形成債務(wù)。這種債務(wù)不是金融債務(wù),而是技術(shù)和設(shè)計(jì)債務(wù)。這些債務(wù)是因?yàn)榻鉀Q獨(dú)立問(wèn)題獲得的。設(shè)計(jì)債務(wù)由大量不可復(fù)用和不一致的樣式和慣例組成,而維護(hù)它們是不可能完成的任務(wù)。隨著時(shí)間的推移,這些債務(wù)的累積會(huì)成為減緩增長(zhǎng)的巨大負(fù)擔(dān)。

創(chuàng)造行為本身并不會(huì)產(chǎn)生債務(wù)——就像花錢(qián)本身并不會(huì)產(chǎn)生金融債務(wù)一樣。但使用設(shè)計(jì)系統(tǒng)將使你的設(shè)計(jì)和代碼保持足夠簡(jiǎn)潔,同時(shí)仍然允許你進(jìn)行升級(jí)和迭代。

3. 一致的設(shè)計(jì)

一致且重復(fù)使用的標(biāo)準(zhǔn)化組件,使你應(yīng)用程序的易用性大大提升。標(biāo)準(zhǔn)化的組件還能讓設(shè)計(jì)師花更少的時(shí)間關(guān)注樣式,花更多的時(shí)間專注于提升用戶體驗(yàn)。

4. 更快的原型

在設(shè)計(jì)系統(tǒng)下工作,你可以像玩樂(lè)高一樣快速拼湊流程和交互,構(gòu)建無(wú)數(shù)的原型和方案進(jìn)行快速驗(yàn)證,從而幫助團(tuán)隊(duì)快速獲得數(shù)據(jù)和結(jié)論。

5. 提高可用性

頁(yè)面樣式的不一致會(huì)影響產(chǎn)品的可用性,當(dāng) CSS 因?yàn)閿?shù)不清的不一致樣式元素和交互增加時(shí),頁(yè)面加載時(shí)間也會(huì)加長(zhǎng),這會(huì)導(dǎo)致很糟糕的用戶體驗(yàn)。它還可能產(chǎn)生沖突的 CSS 和 JavaScript,從而可能破壞你的應(yīng)用程序。通過(guò)使用設(shè)計(jì)程序,通過(guò)構(gòu)建一個(gè)整體的組件庫(kù)(而不是每頁(yè))來(lái)避免這些沖突,從而花費(fèi)更少的時(shí)間來(lái)保證產(chǎn)品質(zhì)量。

6. 建立可訪問(wèn)性程序

可訪問(wèn)性在組件級(jí)別就可以實(shí)現(xiàn),針對(duì)殘疾人士、網(wǎng)速較慢和老舊的計(jì)算機(jī)上進(jìn)行優(yōu)化。這是一個(gè)建立易用性程序很好的方法, 在第 3 章「構(gòu)建設(shè)計(jì)系統(tǒng)」中,Katie Sylor-Miller 解釋了設(shè)計(jì)系統(tǒng)如何幫助你改善產(chǎn)品的可用性,并保證遵守你所在國(guó)家/地區(qū)的法律。

(譯者注:美國(guó)殘疾人法案于 1990 年 7 月通過(guò)并簽署,其中有規(guī)定網(wǎng)站的可用性必須遵守《美國(guó)殘疾人法》(ADA)的相關(guān)內(nèi)容。)

設(shè)計(jì)系統(tǒng)的誤區(qū)

即使有上述說(shuō)的這些好處,在團(tuán)隊(duì)內(nèi)部推行一個(gè)設(shè)計(jì)系統(tǒng)的時(shí)候,仍然很難說(shuō)服團(tuán)隊(duì)成員。設(shè)計(jì)師可能會(huì)感到局限或束縛,但通常這些被感知到的弱點(diǎn)正是設(shè)計(jì)系統(tǒng)的最大優(yōu)勢(shì)。

讓我們來(lái)揭穿那些你在推行設(shè)計(jì)系統(tǒng)時(shí)經(jīng)常會(huì)遇到的誤區(qū)吧。

誤區(qū)1:過(guò)于局限

誤區(qū):負(fù)責(zé)深入獨(dú)立業(yè)務(wù)的設(shè)計(jì)師看到的設(shè)計(jì)標(biāo)準(zhǔn)可能會(huì)與其他需求的不一樣,因此,他們會(huì)認(rèn)為通用的設(shè)計(jì)系統(tǒng)過(guò)于局限,可能無(wú)法滿足某些特定業(yè)務(wù)的需求。

現(xiàn)實(shí):設(shè)計(jì)師通常會(huì)設(shè)計(jì)出自定義的解決方案以滿足應(yīng)用中的獨(dú)立的業(yè)務(wù),從而增加了設(shè)計(jì)和技術(shù)的負(fù)擔(dān)。而使用設(shè)計(jì)系統(tǒng),這些被設(shè)計(jì)的新解決方案可以被反饋到設(shè)計(jì)系統(tǒng)里面,使每個(gè)人都可以使用這些改進(jìn)方案。

誤區(qū)2:缺乏創(chuàng)造力

誤區(qū):如果設(shè)計(jì)師被限制在一個(gè)設(shè)計(jì)系統(tǒng)下做設(shè)計(jì),那么他將不能去自由地探索設(shè)計(jì)風(fēng)格。前端的工作通常包含著各種樣式風(fēng)格的更新。對(duì)應(yīng)用程序的風(fēng)格進(jìn)行改版通常不是一個(gè)小任務(wù)。這也可能是一個(gè)很大的風(fēng)險(xiǎn),因?yàn)閺氖逻@項(xiàng)工作會(huì)移除一部分的舊資源,可能會(huì)對(duì)可用性產(chǎn)生負(fù)面影響。

現(xiàn)實(shí):設(shè)計(jì)系統(tǒng)的組成部分是相互關(guān)聯(lián)的,這意味著當(dāng)一個(gè)位置進(jìn)行更改時(shí),這項(xiàng)更改會(huì)在整個(gè)系統(tǒng)中同步,這使得系統(tǒng)內(nèi)的樣式更新工作變得輕而易舉,但影響卻大得多。以前是幾周甚至幾月的工作量,現(xiàn)在可以在一個(gè)下午就能完成。

誤區(qū)3:一勞永逸

誤區(qū):設(shè)計(jì)和構(gòu)建完設(shè)計(jì)系統(tǒng)后,工作就完成了。

現(xiàn)實(shí):設(shè)計(jì)系統(tǒng)是有生命的,這意味著需要不斷對(duì)其進(jìn)行維護(hù)和改進(jìn)。但是由于應(yīng)用是由設(shè)計(jì)系統(tǒng)的復(fù)用性組件提供支持的,因此該應(yīng)用會(huì)自動(dòng)同步設(shè)計(jì)系統(tǒng)的改進(jìn)內(nèi)容,從而減少維護(hù)應(yīng)用程序的工作量。這就是設(shè)計(jì)系統(tǒng)提供的擴(kuò)展能力。

總結(jié)

設(shè)計(jì)系統(tǒng)不是一時(shí)流行的方法,也不是未經(jīng)檢驗(yàn)的假設(shè)。為了讓設(shè)計(jì)找到與技術(shù)的快速發(fā)展相匹配的同等方案,基于組件的設(shè)計(jì)和開(kāi)發(fā)是一種行之有效的可靠解決方案。

現(xiàn)在你已經(jīng)了解了創(chuàng)建設(shè)計(jì)系統(tǒng)的真正價(jià)值,讓我們?cè)谙乱徽轮猩钊胩接憣?shí)際的設(shè)計(jì)過(guò)程吧。

文章來(lái)源:優(yōu)設(shè)    作者:彩云譯設(shè)計(jì)

Vue.js 常用系統(tǒng)指令

seo達(dá)人

1.v-on :可以用 v-on 指令監(jiān)聽(tīng) DOM 事件,并在觸發(fā)時(shí)運(yùn)行一些 JavaScript 代碼



(1)v-on:click綁定點(diǎn)擊事件



<!DOCTYPE html>

<html>

   <head>

      <meta charset="utf-8" />

      <title>v-on:click</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

   <body>

      <div id="app">

         {{message}}  

         <button v-on:click="fun1('test')">vue的onclick</button>

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:'#app',

         data:{

             message:'hello vue'

         },

         methods:{

             fun1:function (msg) {

               this.message=msg;

                }

         }

      });

      

   </script>

</html> 









(2)v-on:keydown事件會(huì)在用戶按下一個(gè)鍵盤(pán)按鍵時(shí)發(fā)生



<!DOCTYPE html>

<html>

 

   <head>

      <meta charset="utf-8" />

      <title>v-on:keydown</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

 

   <body>

      <div id="app">

         Vue:<input type="text" v-on:keydown="fun($event)">

         <hr/>

         傳統(tǒng)JS:<input type="text"  οnkeydοwn="showKeyCode()"/>

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:"#app",

         methods:{

             / $event 它是vue中的事件對(duì)象  和我們傳統(tǒng)js的event對(duì)象是一樣的  /

             fun:function(event){

                    var keyCode = event.keyCode;

                    if(keyCode < 48  || keyCode > 57){

                        //不讓鍵盤(pán)的按鍵起作用

                        event.preventDefault();

                    }

            }

         }

      });

 

 

      //傳統(tǒng)js的鍵盤(pán)按下事件

      function showKeyCode(){

         //event對(duì)象和我們的document對(duì)象以及window對(duì)象是一樣的,可以不用定義直接使用

         var keyCode = event.keyCode;

         if(keyCode < 48  || keyCode > 57){

            //不讓鍵盤(pán)的按鍵起作用

            event.preventDefault();

         }

         // alert(keyCode);

         // if(event.keyCode == 13){

         //     alert("你按的是回車(chē)");

         // }

      }

   </script>

 

</html>





(3)v-on:mouseover  當(dāng)鼠標(biāo)指針位于元素上方時(shí),會(huì)發(fā)生 mouseover 事件



<!DOCTYPE html>

<html>

 

   <head>

      <meta charset="utf-8" />

      <title>v-on:mouseover</title>

      <style>

         #div {

            background-color: red;

            width:300px;

            height:300px;

         }

      </style>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

 

   <body>

      <div id="app">

         <div @mouseover="fun1" id="div">

            <textarea @mouseover="fun2($event)">這是一個(gè)文件域</textarea>

         </div>

 

         <!--<div οnmοuseοver="divmouseover()" id="div">

            <textarea οnmοuseοver="textareamouseover()">這是一個(gè)文件域</textarea>

         </div>-->

      </div>

   </body>

   <script>

      //view model

        /*

       
@事件名稱  就是  v-on:事件名稱的簡(jiǎn)寫(xiě)方式

        @mouseover它就等同于v-on:mouseover

         
/

      new Vue({

         el:"#app",

         methods:{

            fun1:function(){

                alert("鼠標(biāo)懸停在div上了");

            },

            fun2:function(event){

                alert("鼠標(biāo)懸停在textarea上了");

                    event.stopPropagation();

            }

         }

      });

 

 

      //傳統(tǒng)的js方式

      function divmouseover(){

          alert("鼠標(biāo)移動(dòng)到了div上了");

      }

 

      function textareamouseover(){

          alert("鼠標(biāo)移動(dòng)到了textarea上了");

          event.stopPropagation();

      }

   </script>

 

</html>





(4).Vue.js 為 v-on 提供了事件修飾符來(lái)處理 DOM 事件細(xì)節(jié),如:event.preventDefault() 或 event.stopPropagation()。注意:該方法將通知 Web 瀏覽器不要執(zhí)行與事件關(guān)聯(lián)的默認(rèn)動(dòng)作(如果存在這樣的動(dòng)作)



Vue.js通過(guò)由點(diǎn)(.)表示的指令后綴來(lái)調(diào)用修飾符。

.stop

.prevent

.capture

.self

.once

<!DOCTYPE html>

<html>

 

   <head>

      <meta charset="utf-8" />

      <title>v-on:事件修飾符</title>

      <style>

         #div {

            background-color: red;

            width:300px;

            height:300px;

         }

      </style>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

 

   <body>

      <div id="app">

         <form @submit.prevent action="http://www.itheima.com" method="post" >

            <input type="submit" value="提交">

         </form>

         <!--<form action="http://www.itheima.com" method="post" οnsubmit="return checkForm()">

            <input type="submit" value="提交">

         </form>-->

         <hr/>

         <div @mouseover="fun1" id="div">

            <textarea @mouseover.stop="fun2($event)">這是一個(gè)文件域</textarea>

         </div>

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:"#app",

         methods:{

                fun1:function(){

                    alert("鼠標(biāo)懸停在div上了");

                },

                fun2:function(event){

                    alert("鼠標(biāo)懸停在textarea上了");

                }

         }

      });

      

      

      //傳統(tǒng)js方式

      function checkForm(){

          alert(1);

          //表單驗(yàn)證必須有一個(gè)明確的boolean類型返回值

         //在應(yīng)用驗(yàn)證方法時(shí)必須加上 return  方法名稱

         return false;

      }

   </script>

 

</html>

 







 



2.v-text與v-html



<!DOCTYPE html>

<html>

   <head>

      <meta charset="utf-8" />

      <title>v-text與v-html</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

   <body>

      <div id="app">

         <div v-text="message"></div>

         <div v-html="message"></div>

         <!--<div id="div1"></div>

         <div id="div2"></div>-->

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:"#app",

         data:{

             message:"<h1>Hello Vue</h1>"

         }

      });



      //傳統(tǒng)js的innerText和innerHTML

      window.onload = function(){

          document.getElementById("div1").innerHTML="<h1>Hello</h1>";

            document.getElementById("div2").innerText="<h1>Hello</h1>";

      }

   </script>

</html>





 



(2)v-bind 插值語(yǔ)法不能作用在 HTML 特性上,遇到這種情況應(yīng)該使用 v-bind指令



<!DOCTYPE html>

<html>



   <head>

      <meta charset="utf-8" />

      <title>v-bind的使用</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>



   <body>

      <div id="app">

         <font size="5" v-bind:color="ys1">傳智播客</font>

         <font size="5" :color="ys2">黑馬程序員</font>

      </div>

   </body>

   <script>

      //view model

      //插值表達(dá)式不能用于html標(biāo)簽的屬性取值

      //要想給html標(biāo)簽的屬性設(shè)置變量的值,需要使用v-bind

      //v-bind也可以簡(jiǎn)化寫(xiě)法   直接使用:

      new Vue({

         el:"#app",

         data:{

             ys1:"red",

            ys2:"green"

         }

      })

   </script>



</html>





(3)v-model



<!DOCTYPE html>

<html>

   <head>

      <meta charset="utf-8" />

      <title>v-model</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

   <body>

      <div id="app">

         <form action="" method="post">

            用戶名:<input type="text" name="username" v-model="user.username"><br/>

            密碼:<input type="text" name="password" v-model="user.password"><br/>

            <!-- v-model替換原來(lái)的value屬性的值,用value獲取不到-->

         </form>

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:"#app",

         data:{

            user:{

                username:"test",

               password:"1234"

            }

         }

      })

   </script>

</html>





(4)v-for



 



<!DOCTYPE html>

<html>

   <head>

      <meta charset="utf-8" />

      <title>v-for遍歷數(shù)組</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

   <body>

      <div id="app">

         <ul>

            <li v-for="(item,index) in arr ">{{item}}={{index}} </li>

            <!--index是索引的意思,用插值表達(dá)式輸出 -->

         </ul>

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:"#app",

         data:{

             arr:[1,2,3,4,5]

         }

      })

   </script>

</html>





 



<!DOCTYPE html>

<html>

   <head>

      <meta charset="utf-8" />

      <title>v-for遍歷對(duì)象</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

   <body>

      <div id="app">

         <ul>

            <li v-for="(key,value) in product ">{{value}}===={{key}} </li>

         </ul>

      </div>

   </body>

   <script>

      //view model

        new Vue({

            el:"#app",

            data:{

               product:{

                   id:1,

               name:"筆記本電腦",

               price:5000

            }

            }

        })

   </script>

</html>





<!DOCTYPE html>

<html>



   <head>

      <meta charset="utf-8" />

      <title>v-for遍歷對(duì)象</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>



   <body>

      <div id="app">

         <table border="1">

            <tr>

               <td>序號(hào)</td>

               <td>編號(hào)</td>

               <td>名稱</td>

               <td>價(jià)格</td>

            </tr>

            <tr v-for="(product,index) in products ">

               <td>{{index}}</td>

               <td>{{product.id}}</td>

               <td>{{product.name}}</td>

               <td>{{product.price}}</td>

            </tr>

         </table>

      </div>

   </body>

   <script>

      //view model

        new Vue({

            el:"#app",

            data:{

                products:[

                   { id:1,name:"筆記本電腦",price:5000 },

                    { id:2,name:"手機(jī)",price:3000 },

                    { id:3,name:"電視",price:4000 }

                ]

            }

        })

   </script>



</html>





3.v-if與v-show



v-if是根據(jù)表達(dá)式的值來(lái)決定是否渲染元素

v-show是根據(jù)表達(dá)式的值來(lái)切換元素的display css屬性

 

<!DOCTYPE html>

<html>

   <head>

      <meta charset="utf-8" />

      <title>v-if與v-show</title>

      <script src="js/vuejs-2.5.16.js"></script>

   </head>

   <body>

      <div id="app">

         <span v-if="flag">傳智播客</span>

         <span v-show="flag">itcast</span>

         <button @click="toggle">切換</button>

      </div>

   </body>

   <script>

      //view model

      new Vue({

         el:"#app",

         data:{

             flag:false

         },

         methods:{

             toggle:function(){

                 this.flag = !this.flag;

            }

         }

      })

   </script>

</html>


vue框架漸進(jìn)性的理解和mvvm模式的理解

seo達(dá)人

引言

現(xiàn)在市場(chǎng)很多前端開(kāi)發(fā)的招聘崗位都或多或少的要求你要掌握vue,可以說(shuō)vue在國(guó)內(nèi)是非常的火爆的,下面我給大家介紹一下vue框架吧!

vue是漸進(jìn)式框架



vue的核心是一個(gè)視圖模板引擎,但是這并不能說(shuō)明vue不是一個(gè)框架,如上圖所示在聲明式渲染(視圖模板)基礎(chǔ)上,vue可以添加組件系統(tǒng)component,vue-router客戶端路由,vuex的狀態(tài)管理,vue-cli構(gòu)建工具來(lái)構(gòu)建一個(gè)完整的框架,更重要的是這些功能相互獨(dú)立,你可以任意選用你項(xiàng)目需要的部件,不一定非要全部整合在一起(就像是vuex它是一個(gè)很好的可以管理組件之間共享狀態(tài)的部件,但非必須在你的每一個(gè)項(xiàng)目中使用它,如果說(shuō)你的項(xiàng)目相對(duì)簡(jiǎn)單,組件之間的通信相對(duì)簡(jiǎn)單你完全可以不使用它),可以看到漸進(jìn)式,其實(shí)就是vue的使用方式,同時(shí)也能看到vue的設(shè)計(jì)理念

vue是mvvm模式

為什么說(shuō)vue是mvvm模式呢?這個(gè)大家首先要知道m(xù)vvm是什么。mvvm是Model-View-ViewModel的簡(jiǎn)寫(xiě),即模型視圖視圖模型。模型是指后端傳過(guò)來(lái)的數(shù)據(jù),視圖是指我們看到的頁(yè)面,視圖模型是mvvm框架的核心,他是連接view和model的橋梁,它有兩個(gè)方向,第一將后端傳來(lái)的數(shù)據(jù)轉(zhuǎn)換成頁(yè)面可以看到的視圖,第二,將用戶在頁(yè)面上的交互轉(zhuǎn)化成為后端數(shù)據(jù),我們稱之為雙向綁定。

總結(jié)mvvm模式的視圖和模型是不能直接通信的,它們通過(guò)ViewModel來(lái)通信,ViewModel通常要實(shí)現(xiàn)一個(gè)observer觀察者,當(dāng)數(shù)據(jù)發(fā)生變化,ViewModel能夠監(jiān)聽(tīng)到數(shù)據(jù)的這種變化,然后通知到對(duì)應(yīng)的視圖做自動(dòng)更新,而當(dāng)用戶操作視圖,ViewModel也能監(jiān)聽(tīng)到視圖的變化,然后通知數(shù)據(jù)做改動(dòng),這實(shí)際上就實(shí)現(xiàn)了數(shù)據(jù)的雙向綁定。并且MVVM中的View 和 ViewModel可以互相通信

vue框架可以理解為是ViewModel,它可以實(shí)現(xiàn)dom監(jiān)聽(tīng)和數(shù)據(jù)綁定

vue的數(shù)據(jù)綁定原理



當(dāng)你把JavaScript對(duì)象傳入vue實(shí)例作為data選項(xiàng),vue會(huì)遍歷此對(duì)象的所以屬性,并使用Object.defineProperty把這些屬性轉(zhuǎn)換為getter和setter,每一個(gè)組件都有一個(gè)watcher實(shí)例,它會(huì)在組件渲染過(guò)程中,把接觸過(guò)的數(shù)據(jù)記錄為依賴,當(dāng)依賴的setter被觸發(fā)是,他會(huì)通知watcher,重而使關(guān)聯(lián)的數(shù)據(jù)重新渲染,以下是代碼展示。



<div id = "box"></div>

var obox = document.getElementById('box')

var obj = {}

object.defineProperty(obj,'myname',{

get () {

// obj設(shè)置了一個(gè)myname屬性,當(dāng)訪問(wèn)obj.myname屬性會(huì)執(zhí)行g(shù)et方法

},

set (data) {

// 當(dāng)修改myname屬性會(huì)執(zhí)行set方法

// data會(huì)得到你修改的值

obox.innerHTML = data

}

})



object.definePeoperty有一下缺點(diǎn): {

1:無(wú)法監(jiān)聽(tīng)es6的set,map變化

2:無(wú)法監(jiān)聽(tīng)class類型的數(shù)據(jù)

3:屬性的新增和刪除也無(wú)法監(jiān)聽(tīng)

4:數(shù)組元素的新整和刪除也無(wú)法監(jiān)聽(tīng)

}




JS循環(huán)結(jié)構(gòu)有哪些?循環(huán)結(jié)構(gòu)概述

seo達(dá)人

所謂循環(huán),就是重復(fù)執(zhí)行一段代碼,計(jì)算機(jī)的判斷能力和人相比差的很遠(yuǎn),計(jì)算機(jī)更擅長(zhǎng)一件事情——不停的重復(fù)。而我們?cè)贘avaScript中把這叫做循環(huán)。下面讓我們來(lái)了解了解JavaScript里的循環(huán)。



js循環(huán)結(jié)構(gòu)有哪些

js循環(huán)結(jié)構(gòu)有三種



for循環(huán) ==> 用來(lái)多次遍歷代碼塊

while循環(huán) ==> 當(dāng)指定條件為true時(shí),循環(huán)代碼塊

do while ==> 當(dāng)指定條件偽true時(shí),循環(huán)代碼塊

1、for循環(huán)

for是由兩個(gè)部分組成,條件控制和循環(huán)體

語(yǔ)法:



for(初始化表達(dá)式;循環(huán)條件表達(dá)式;循環(huán)后的操作表達(dá)式){

需要重復(fù)的代碼塊;

}



for語(yǔ)句結(jié)構(gòu)如圖:



for循環(huán)的執(zhí)行順序



1.初始化表達(dá)式

  1. 循環(huán)條件表達(dá)式
  2. 需要重復(fù)的代碼塊
  3. 循環(huán)后的操作表達(dá)式



    簡(jiǎn)單的for循環(huán),循環(huán)執(zhí)行一次會(huì)改變一個(gè)變量的值

    舉例:輸出1到100的值



    for(var i=1; i <= 100; i++){

    //在循環(huán)開(kāi)始時(shí)設(shè)置一個(gè)變量i;//定義運(yùn)行循環(huán)的條件i<=100;//每個(gè)循環(huán)執(zhí)行后,變量增加1

    console.log(i);

    }



    2、while循環(huán)

    while循環(huán)會(huì)重復(fù)執(zhí)行一段代碼,直到某個(gè)條件不再滿足。

    語(yǔ)法:



    while(條件表達(dá)式語(yǔ)句){

    執(zhí)行的代碼塊;

    }



    while循環(huán)結(jié)構(gòu)如圖:



    while執(zhí)行順序

    當(dāng)我們的使用條件條件返回值是true,就會(huì)執(zhí)行大括號(hào)里面的代碼塊,執(zhí)行完大括號(hào)的語(yǔ)句之后,會(huì)重復(fù)大括號(hào)里的語(yǔ)句,直到判定條件返回值為false,才會(huì)結(jié)束循環(huán)。



    案例:



    var i = 0;

    while (i < 10){

    console.log(i);

    i++;

    }

    //while循環(huán)會(huì)先判定條件,再根據(jù)條件是否成立達(dá)成決定是否進(jìn)入循環(huán)

    //如果條件一開(kāi)始就是false ,則不會(huì)進(jìn)入循環(huán)



    缺點(diǎn):



    使用while語(yǔ)句的時(shí)候,一定要寫(xiě)大括號(hào)

    如果沒(méi)有條件的話,會(huì)無(wú)限的運(yùn)行下去,造成死循環(huán)。

    3、do while循環(huán)的結(jié)構(gòu)

    do while 結(jié)構(gòu)的基本原理和while結(jié)構(gòu)是基本相同的,但是它保證循環(huán)體至少被執(zhí)行一次。因?yàn)樗窍葓?zhí)行代碼,后判斷條件

    語(yǔ)法:



    do {

    執(zhí)行語(yǔ)句塊;

    }

    while(條件表達(dá)式語(yǔ)句);



    do while 執(zhí)行順序:

    先執(zhí)行一次code,再做判斷。與while循環(huán)不同,do while無(wú)論條件如何 都會(huì)執(zhí)行一次代碼

    案例:



    var i = 0;

    do{

    console.log(i);

    i++;

    }while(i<10);



    while 和 do while的不同

    while: 先判斷 再執(zhí)行 條件不成立 循環(huán)體 一遍都不執(zhí)行

    do…while: 先執(zhí)行 再判斷 條件不成立 循環(huán)體 至少執(zhí)行一遍


日歷

鏈接

個(gè)人資料

存檔