css選擇器前綴,強大利用JS應用的Javascript網格插件有哪些呢?
工具類
方便操作對象,數組等的工具庫
underscore.js
lo-dash 與underscore.js的api基本一致。與underscore比其優勢是,效率高;可自定義構建
Sugar 在原生對象上增加一些工具方法
functional.js 提夠了一些Curry的支持
Watch.js 監視對象或屬性的變化
bacon.js 函數式編程,cool
streamjs 用流的方式來對數組,對象進行系列操作
異步流程控制
eventproxy 樸靈出品
Arbiter.js 詳細
發布訂閱
q Promise風格的
Async.js
mock
Mock.js 生成隨機數據和mock Ajax 請求
jQuery-mockjax mock ajax請求
時間庫
moment
datejs
瀏覽器探測
Bowser 探測具體瀏覽器和版本
ua-parser-js 探測具體瀏覽器和版本,操作系統,設備類型等
調試
console-polyfill 能放心的使用 console.log()之類的console方法
log 讓控制臺輸出的log有樣式
Konsole.js 在頁面的一個元素里輸出log信息 詳細
uri.js uri操作
cookie 增刪改cookie的工具庫
director 前端路由庫 詳細
BigDecimal.js 提高精度的數字操作
JSDoc 根據javascript文件中注釋的信息,生成API文檔 詳細
hotkeys 鍵盤事件的封裝
MD5 用 MD5 的方式加密文件的庫
瀏覽器增強類
讓一些舊瀏覽器變牛逼的庫
Selectivizr 讓IE 6-8一些的css3選擇器
ieBetter 讓ie6-8有高級瀏覽器的特性
ExplorerCanvas 讓IE8-的瀏覽器支持canvas
CSS3 Pie 讓IE6-9支持border-radious,box-shadow,linear-gradient。 可以使用.htc文件(注意Mine type)或.js文件。在用Pie.js時,box-radious的元素有背景色時,不顯示背景色。。。
formFive 讓舊的瀏覽器支持HTML5表單的一些特性,如 placeholder,autofocus
https://github.com/anselmh/object-fit 讓瀏覽器支持object-fit這css規則
HTML5 Cross Browser Polyfills 一堆Polyfills
flexibility 讓舊的 IE 也支持 Flexbox
選擇器增強
Lining.js 讓瀏覽器實現類似::nth-line(), ::nth-last-line()的效果
未歸類
prefixfree 用了它,寫css時,就不需要加瀏覽器的前綴了
表單類
jquery-file-upload 上傳文件組件 詳細
zTree 文件樹形視圖控件
Treed 樹編輯器。感覺展示的感覺很像思維導圖
FileAPI 對文件選擇框內的文件的一些處理
表單驗證
.Validate 詳細
jquery-Validation-Engine
表單元素美化
uniform 提供對下拉框,單,復選框,按鈕等表單元素的美化
select2 多選下拉框
selectivity 和unfirom比較類似
DropKick 下拉框,單,多選。外觀比uniform好
switchery ios7風格的開關組件
nouislider 用滾動條來設置/控制(音量等)
range.css 美化input[type=range]元素的外觀
圖片類
holderjs 生成占位圖片
lazyload
imagesLoaded 選取的圖片都加載好后執行調回
CSSgram 用CSS3的Filter實現Instagram濾鏡的庫
圖標類
Icon Font匯總
SVG做的圖標
svgicons
iconic
HYBICON 帶交互效果。如 hover, click
HTML字符實體圖標
http://www.amp-what.com/
transformicons 圖標點擊時,會有一些變換效果。如,加號變成叉號
css3patterns css3 做的可平鋪紋理。瀏覽器兼容性不好。
瀏覽圖片
fancybox 彈出查看圖片,視屏等等 demo
yoxview 彈出查看圖片,圖片尺寸縮放很自然
圖片墻
wookmark
UI 框架
WeUI 由微信官方設計團隊為微信 Web 開發量身設計。
Framework7
UI 組件類
拖拽
dragula 支持Draggable,Dropable和Sortable。感覺比jqueryUI的輕量級,好用的樣子
angular-dragula dragular 官方的 angular 版本
數據可視化(圖表)
Echarts 百度出品
highcharts 功能強大。是收費的。
Plottable.JS 基于D3的一個圖表庫
flot 文檔不給力
chartJs 中文文檔 demo很漂亮,很清晰。比較輕量級。
ichartJs 中國的一個家伙搞的,感覺還不錯。
時間選取組件
foundation-datepicker
DatePicker 一個簡單的日歷 詳細
full calendar 支持脫放的方式來改變待辦事宜的時間
Simple Events Calendar 外觀很喜歡。收費 5$
jQuery ui datepicker 經典,不是很好看
pickadate 輕量級,手機友好的,漂亮。但貌似只能在彈出層中顯示,而沒有下拉這種方式顯示。
zebra-datepicker 可配置性很強。但貌似只能在彈出在右上方。。。
bootstrap-datepicker bootstrap風格。
dateRangePicker 選取時間段。bootstrap風格。該組件依賴Twitter Bootstrap, Moment.js和jQuery.
自定義滾動條
perfect scrollbar 輕量級的滾動條。外觀與mac上chrome的滾動條一樣。
iscroll 在移動設備上用不錯
加載(Loding)效果
CSS Spinners CSS做的
Loaders.css CSS做的
表格組件
jsGrid Data Grid。 詳細
backgrid 基于Backbone.js的DataGrid
excellentexport 把表格的內容生成excel。兼容 Firefox, Chrome, IE6+
datatables 表格可交互(對內容進行排序,刪除等)
handsontable 生成Excel外觀的數據
JSpreadsheets 表格數據的組件庫
選取顏色
Spectrum
分享到SNS
JiaThis 生成分享代碼。
編輯器
ace 代碼編輯器,可以用來做demo演示
ckeditor
ueditor 百度做的
tinymce 對html內容進行實時的編輯
summernote 在移動設備上用不錯
通知組件
notie.js
HTML5播放器
jwplayer 被大量網站使用
html5media 簡單的h5player,輕量級
jplayer 功能強太,可換膚
展示
Impress.js 各種旋轉,和奇特的體驗
fullPage 全屏顯示。用滾輪來翻頁 詳細
zepto.fullpage 專注于移動端的fullPage.js,依賴Zepto
pagePiling 和fullPage類似
turn.js 做一本書,帶漂亮的翻頁的效果
幻燈
slidesjs 挺好用的,只是那幻燈導航的CSS都要自己寫,呵呵 詳細
iSlider 無任何插件依賴的手機平臺javascript滑動組件 詳細
bgstretcher 全屏幻燈,會隨著頁面大小的變化而變化。
Swiper 開源、免費、強大的移動端觸摸滑動插件 Swiper中文網
coin-slider 兼容IE6。蠻好的~。不過其切換方式是一塊塊的。不能配置切換方式。。。
wowslider 幻燈切換時各種很炫的效果。收費。
cycle2 普通的幻燈,竟然不支持垂直滾動。。。
jcarousel 普通的幻燈,不兼容IE6
reveal 3d滾動。做ppt相當不錯
nodePPT 國人做的,做ppt也相當不錯。有些方面比 reveal做的還好。但生成導出的html有些問題
roundabout 3d切換,看的后面圖片的邊
彈出框
Magnific-Popup 兼容PC,Mobile。還不錯,有5k+的star
layer 國人開發的,兼容ie6+。不喜歡其調用方式。
動畫效果
mixitup 用漂亮的動畫效果來完成排序和篩選
jQuery.Marquee 跑馬燈效果
quickflip 卡片翻轉效果
卡片翻轉效果2 兼容性可以。寫的比較簡單:1,只支持x方向翻轉 2,類名都是規定好的 3,只能被調用一次。 需要改寫一下。我的改進版見這里
TheaterJS 模擬兩個人在屏幕上對話
midnight.js 文字顏色隨著背景變,屌炸了
color-animation jquery的顏色漸變動畫插件。jquery的動畫不支持顏色值的變化。改庫提供了這個支持。
transit 對元素進行css的變換
tagcanvas 3D標簽云效果 詳細
iconate 圖片切換動畫
Snap.js 左/右側導航的出現效果
CSS shake 抖動動畫
ClickSpark.js 點擊后的一些酷炫的效果
視覺差插件
scrollorama 比較簡單
superscrollorama 能做的效果更多,但要用第三方Tween的庫,使用起來比較復雜。
scrolldeck
flash
swfobj 能夠自動檢測PC、Mac機器上各種主流瀏覽器對Flash插件的支持情況。它使得插入Flash媒體資源盡量簡捷、安全。而且它是非常符合搜索引擎優化的原則的。此外,它能夠避免您的HTML、XHTML中出現object、embed等非標準標簽,從而符合更加標準。 詳細
抽獎
wScratchPad 刮刮卡刮獎效果
jqueryrotate 旋轉插件。可以用來做轉盤抽獎效果
用戶體驗增強類
Intro.js 用來介紹網站的功能很不錯。也可以做新手引導。
blockUI Lolding組件。
simple-hint 提示信息。用css做的。兼容性IE 9+。
dotdotdot 文字溢出時,添加在文字末尾加省略號
jQuery-menu-aim 二級菜單的切換如Amazon主頁上一樣迅速
AnythingZoomer 放大鏡功能
美化/高亮語法代碼
google-code-prettify
DlHighlight 僅支持JavaScript、CSS、XML、HTML 這4語法高亮
please 按要求隨機舒服的顏色
Awesomplete 輸入的智能提示,自動補全
proTip 提示。感覺比 Bootstrap 的 tip 好
Hammerjs 手勢庫。封裝了 Swipe, Tap, Pinch, Pan等手勢
動畫
velocity 提高Jquery動畫的性能。以及顏色動畫之類的新特性。
SVG
Snap.svg 操作 SVG 的 JS 庫。號稱 SVG 的 jQuery。demo
walkway 以動畫的方式,漸漸地畫出 SVG 的路徑。
測試
Mocha
Chai
Should
Snoion
DeviceMock.js mock 設備。
其他類
ZeroClipboard 將內容復制到剪切板兼容主流瀏覽器的解決方案 詳細
html2canvas html轉化成canvas,可以用來做截圖。詳細
Ink 響應式html郵件框架
性能測試
抓取,解析RSS內容(不能跨域,所以后臺要做代理,所謂的解析Rss其實就是解析xml)
jFeed
jRss 簡單版的jFeed
scriptcam 與攝像頭交互
cylon.js 機器人框架,支持35個平臺
Masonry 一個瀑布流框架
devices.css 移動設備邊框的外觀。做原型的時候用不錯。
Bootstrap相關類
Bootbox.js 對bootstrap的彈出框做的一些封裝
免費皮膚
AdminLTE
JS Plugins倉庫
jQuery Cards 高質量的 jQuery 插件網站
jster
node modules
npmrank Sort npm packages by page rank
YOU MIGHT NOT NEED JQUERY PLUGINS 不依賴 jQuery 的 js 插件。
awesome-nodejs
Libraries.io 各種語言的庫
OniUI 去哪兒網做的一套基于Avalon的框架
常用的移動端框架
zepto.js
語法與jquery幾乎一樣,會jquery基本會zepto~
最新版本已經更新到1.16
iscroll.js
解決頁面不支持彈性滾動,不支持fixed引起的問題~
實現下拉刷新,滑屏,縮放等功能~
最新版本已經更新到5.0
underscore.js
筆者沒用過,不過聽說好用,推薦給大家~
該庫提供了一整套函數式編程的實用功能,但是沒有擴展任何JavaScript內置對象。
最新版本已經更新到1.8.2
滑屏框架
適合上下滑屏、左右滑屏等滑屏切換頁面的效果
slip.js
iSlider.js
fullpage.js
swiper.js
flex布局
flex布局目前可使用在移動中,并非所有的語法都全兼容,效果良好~
怎樣在網頁中做出精彩的文字排版?
所以這里技巧吧!
1.不要使用過多的字體
網站排版中建議最多不要超過3種字體類型,不然會使網站看起來松散和不專業,不僅太多的字體類型會造成這種問題,太多的字體尺寸也會破壞網頁布局。
通常情況下,將字體類型的數量限制在最小數量(2個是很多,1個通常就夠了),整個網站堅持使用相同的原則。如果使用多個字體,請確保倆個字體是和諧的。以下面的字體組合為例,Georgia和Verdana的搭配相得益彰,相對比較和諧。相比于右邊Baskerville和Impact則會有明顯的沖突感,非襯線Impact明顯的超過了Baskerville的視覺沖擊力。 而在中英文排版中,建議大家中文使用標準中文字體,而英文、數字和字符使用標準的英文字體。以下圖為例,可做對比參考。 左:中文(漢儀旗黑) 英文(DIN Next LT Pro) 標點符號使用半角字符 右:中文(漢儀旗黑) 英文(漢儀旗黑) 標點符號使用全角字符。
2.盡量使用標準字體
在Google Web Font或者Typekit,和國內的“有字庫”的字體嵌入式服務有很多有趣的字體,對于國內設計師來說,痛苦的是中文字體會很大,一個字體動則幾兆,十幾兆的,這樣用戶在會增加用戶瀏覽網站的載入時間;反之英文字體26個字母大小寫,加數字標點符號一共幾百k的字體是很容易在網頁中使用的。
盡可能選擇標準字體(近幾年網頁中通常使用思源黑體,PingFang,英文可以使用Arial,Calibri或者其他常見的易于屏幕閱讀的黑體字,如沒有特殊概念指導盡可能避免使用襯線字體,如宋體) 不是每位用戶都可以在終端上看到同一個字體,意味著你選擇的適合的字體,用戶有可能看不到。 用戶更熟悉標準字體,因此他們可以更快的閱讀 特殊的、并且少量的字體可以制作成.svg格式的素材嵌入Web使用 良好的排版會使用戶更加關注內容本身,而不是字體的類型。
3.限制一行文字的長度
保證每一行文字的字符數量是文本可讀的關鍵。不僅由設計師來定義文本的寬度,同時需要根據用戶的可讀性來定義。 太寬-會使得單行文字太長,讀者的眼睛會難于專注文字。因為長時間閱讀容易串行,大段的文本中很難找到正確的行。 太短-會使得用戶的眼睛經常回到下一行文本,會打破讀者的閱讀節奏,長時間閱讀造成視覺疲勞。太短也會傾向于向讀者發出一種信號,使得讀者沒有讀完當前這行就去跳到下一行閱讀,可能會忽略潛在的重要詞句。
對于移動設備,應該每行30-40個字符(半角),具體顯示多少個字數,與不同分辨率的屏幕、文本寬度和字體大小都會有關系,設計的原則是:保證用戶可以流暢的閱讀文本,文字不宜太小或太大。以iOS(手機)為例,正文文本最小字號不能小于24px,太小了用戶閱讀會難以閱讀。以百度為例,可作為參考。
4.選擇用有多個字重,屏幕顯示良好的字體
用戶將通過不同屏幕分辨率的終端設備訪問你的網站,大多數用戶界面需要各種大小尺寸的文本(標題、副標題、文本、標注等等)。選擇一款能夠在不同屏幕分辨率的設備上運行良好的字體以保證它的不同尺寸的字體都具有極高可讀性(Readability)和可用性(Usability)也是非常重要的。
近倆年備受大家歡迎的思源黑體和PingFang字體都是不錯的選擇,當然,個人認為漢儀旗黑無論從家族字體的數量、字體質量、屏幕顯示、紙媒印刷上來說都不遜色于前面倆款字體。參與過思源黑體設計的設計師曾說過,思源黑體還是相對比較粗糙的一款字體。 同樣,為了保證在屏幕上清晰可辨,盡量避免使用襯線體,盡管他們很漂亮。
5.使用識別度高的字體
在選擇英文體的時候,有些字體的個別字母極易混淆,特別是“i”和“L”(如下圖所示);以及文字之間的間距。許多中文字體在使用較小字體的時候筆畫會粘到一起(上圖),不容易辨別;所以在選擇字體類型的時候,請檢查你選擇使用的字體,確保不會為用戶和產品造成不必要的損失。
6.避免在界面中大段的使用大寫字母
不要所有文本使用大寫字母,強制用戶閱讀大寫字母,首字母大寫,具有特殊含義的縮寫等情況除外,與小寫字母相比,大量的使用大寫字母會嚴重降低用戶的閱讀效率和愉悅感。
7.將行間距控制在字體的1.5-2.0倍之間
在文字文字排版中,我們又一個特殊的術語,用于表示行與行之間的距離:行間距(或行高)。為了保證文本的可讀性和易讀性,使文本形成線性的閱讀感受,在網頁設計中,通常情況下將行間距控制在字體大小的1.5-2.0倍之間(中文字體)。英文字體推薦使用默認行間距,或根據默認行間距微調。
8.適當的顏色對比度 通常情況下,文本和背景盡量避免使用相同或相似的顏色。
文本越明顯,用戶能夠掃描和閱讀的速度越快。當然,學會通過文本顏色、大小和背景的顏色關系來控制視覺層級也是必要的。 與背景相比,小文本和背景的對比度至少為4.5:1 大文本(14px/18px以上)應該保持與背景3:1以上的對比度
灰色通常作為輔助色使用,根據我自己的項目經驗,給大家分享一套我自己一直在使用的灰色,灰的有層次,清晰的區分信息層級是必要的。
9.避免將文字著色為紅色或綠色
色盲和色弱是我必須要照顧到的一部分用戶,特別是在男性中(8%的男性是色盲)建議使用處顏色以外的其他方式來區分重要的信息(如下劃線,加粗等)。避免使用紅色和綠色單獨傳達信息。因為紅綠色盲是最常見的色盲形式。(現在想想,那些因為紅綠色盲而考不了駕照的童鞋是不是要分分鐘恨死制定紅綠燈規則的人,當然這只是個笑話,使用紅綠燈是因為光學在物理傳播方面的原因,這里不解釋)
雖然在日常生活中我們總是用這種方式告知用戶綠色是表示正確的操作,紅色表示錯誤的操作,反思一下我們是否有去考慮色盲用戶的操作和體驗。或許我們是不是可以考慮換一個方式去表達正確或錯誤?
10.避免文字閃爍
閃爍的文字或內容可能會讓某些用戶感到不適,對于一般用戶而言,這可能分散他們的注意力或者使他們感到煩躁。
雖然在網頁設計中依然有很多需要我們注意的地方,最后,分享給大家一個想法就是:網頁設計中排版很重要。做出正確的排版可以讓你的網站感覺清爽,糟糕的網頁排版會令用戶分心,傾向于關注自己的感受而非內容。排版的關鍵在于使信息層級清晰、用戶易于閱讀、并且保證文字是可讀的。文字的排版不應該增加用戶的認知符合,以求達到尊重內容、尊重用戶的目的。
css怎么能最大化避免瀏覽器兼容性問題?
可以添加瀏覽器的私有前綴,CSS3的瀏覽器私有屬性前綴是一個瀏覽器生產商經常使用的一種方式
-webkit-
-moz-
-ms-
-o-
-khtml-(現在基本都沒有用了,被-webkit-取代)
以及避免使用h5和css3,以兼容ie6,7,8,因為,谷歌和國產基本都是基于谷歌內核,只有ie有兼容性問題
sass系統產品介紹?
Sass是CSS的預處理器,它提供了許多便利的寫法方法
可以使用變量,常量,嵌套,函數,混合,繼承等功能,讓css的開發變得更加簡單可維護。
直接寫出來的sass文件其實就是普通的文本文件,以.sass或.scss作為文件后綴名。
里面可以直接使用css語法以及sass特有的語法特性,完成后通常需要經過編譯成合法的css文件以供瀏覽器使用。
sass的安裝
sass基于Ruby語言開發而成,因此安裝sass前需要安裝Ruby。
安裝完成后需測試安裝有沒有成功,運行CMD輸入以下命令:
ruby -v
如安裝成功會打印
ruby 2.2.2p95 (2015-04-13 revision 50295) [i386-mingw32]
Ruby自帶一個叫做RubyGems的系統,用來安裝基于Ruby的軟件。我們可以使用這個系統來 輕松地安裝Sass和Compass。要安裝最新版本的Sass和Compass,你需要輸入下面的命令:
安裝如下(如mac安裝遇到權限問題需加 sudo gem install sass)
gem install sass
gem install compass
在每一個安裝過程中,你都會看到如下輸出:
Fetching: sass-3.x.x.gem (100%)
Successfully installed sass-3.x.x
Parsing documentation for sass-3.x.x
Installing ri documentation for sass-3.x.x
Done installing documentation for sass after 6 secon
1 gem installed
安裝完成之后,你應該通過運行下面的命令來確認應用已經正確地安裝到了電腦中:
sass -v
Sass 3.x.x (Selective Steve)
compass -v
Compass 1.x.x (Polaris)
Copyright (c) 2008-2015 Chris Eppstein
Released under the MIT License.
Compass is charityware.
Please make a tax deductable donation for a worthy cause: http://umdf.org/compass
sass的編譯
1.命令行編譯;
//單文件轉換命令
sass input.scss output.css
//單文件監聽命令
sass --watch input.scss:output.css
//如果你有很多的sass文件的目錄,你也可以告訴sass監聽整個目錄:
sass --watch app/sass:public/stylesheets
2.編譯工具Koala
3.使用vscode中的Live Sass Compiler插件來實現scss文件的實時編譯
變量
Sass 讓人們受益的一個重要特性就是它為 CSS 引入了變量。你可以把反復使用的 CSS 屬性值 定義成變量,然后通過變量名來引用它們,而無需重復書寫這一屬性值。
變量的定義是以$符號開頭,加上變量名,比如:
$text-warning: red;
$border-radius: 5px;
.tip {
color: $text-warning;
border: 1px solid $border-radius;
}
變量也可以通過加減乘除等運算符號進行計算,比如:
$font-base: 10px;
.article {
font-size: $font-base * 2 - 4px;
border-width: $font-base / 10;
}
變量的注意事項
變量需要提前聲明才能使用,因為編譯是從上往下進行的,如果在還未聲明變量的地方使用,會找不到這個變量。
變量都是全局變量,如果在大括號內部定義的變量則屬于局部變量。
嵌套
通常所用到的選擇器嵌套是這樣的,將新的選擇器放到父級選擇器當中,并且可以無限多級嵌套。
繼承
如果存在兩個class,他們有一些不同但又有許多相似之處,以前的做法可能是把所有樣式重復聲明兩次。但是有sass之后更好的做法是創建一個基礎的class,然后在第二個class中用@extend繼承它,同時還可以添加一些額外的樣式,或者對某些樣式進行重寫。比如我們之前學過bootstrap的按鈕的構建思想,是對基礎樣式進行附加和重寫,而現在想要定義自己的樣式時就可以很方便地進行這一操作了。首先聲明一個標準樣式的class,然后繼承這個樣式,然后設置不同的主題色:
混合
當出現大段大段重用樣式代碼時,獨立的變量就難以應付,這個時候可以通過sass的混合器@mixin 和 @include 實現大段樣式的重用。在定義mixin時,需要在前面添加@符號,使用時需要用@include來引用該@mixin:
導入
導入規則可以從外部文件導入mixin混合器等等。在sass中有一個命名慣例,被導入的樣式文件名用下劃線做前綴。導入的語法是@import “xxx”,這里的xxx不需要帶文件后綴和下劃線前綴。也就是說導入“_style.sass”或者“_style.scss”的時候,只需要寫@import “style”就可以了:
1.為什么要使用SASS?
它是預處理語言,它為CSS提供縮進語法(它自己的語法)。
它允許更有效地編寫代碼和易于維護。
它是包含CSS的所有功能的CSS的超集,是一個開源的預處理器,以 Ruby 編碼。
它提供了比平面CSS好的結構格式的文檔樣式。
它使用可重復使用的方法,邏輯語句和一些內置函數,如顏色操作,數學和參數列表。
2.列出SASS的一些功能?
它是更穩定,強大,與CSS的版本兼容。
它是超集的CSS和基于JavaScript。
它被稱為CSS的語法糖,這意味著它使用戶更容易閱讀或表達的東西更清楚。
它使用自己的語法并編譯為可讀的CSS。
你可以在更少的時間內輕松地編寫CSS代碼。
它是一個開源的預處理器,被解釋為CSS。
3.SASS的優點是什么?
它允許在編程結構中編寫干凈的CSS。
它有助于編寫CSS更快。
它是CSS的超集,幫助設計師和開發人員更有效率和快速地工作。
由于Sass兼容所有版本的CSS,我們可以使用任何可用的CSS庫。
可以使用嵌套語法和有用的函數,如顏色操作,數學和其他值。