亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 軟件應用 > 正文

自動刷新從BrowserSync開始

2024-09-06 19:17:04
字體:
來源:轉載
供稿:網友

請想象這樣一個場面:你開著兩個顯示器,一邊是IDE里的代碼,另一邊是瀏覽器里的你正在開發的應用。此時桌上還放著你的手機,手機里也是這個開發中的應用。然后,你新寫了一小段代碼,按下了ctrl+s保存。緊接著,你的手機和另一個顯示器里的應用,就變成了更新后的效果。你可以馬上檢查效果是否和你預想的一致,甚至都不需要動一下鼠標…

想起來還不錯?嗯,這只是簡單地省略掉那個開發過程中會按好多遍的F5刷新。

自動刷新

“自動刷新”并不是新的概念,但對關注“可見”的預覽效果的前端開發者來說,它非常好用,可以節約很多時間。

我也不是現在才知道這個概念。在這之前,我一直在用LiveReload,它是一個名字上更明顯地寫著“自動刷新”的工具。LiveReload主要搭配瀏覽器插件使用,是很棒的自動刷新工具。

不過,現在我要介紹的是BrowserSync。你會在接下來的內容里看到,它是一個更新、更方便的開發工具。

BrowserSync

LiveReload有所不足的地方是,需要搭配瀏覽器插件。但是,插件是取決于瀏覽器的,Chrome和Firefox都有可用插件,但IE,或者我手機上的瀏覽器,就不能這樣了。這時候只能手工向頁面里添加一段<script>代碼(其實插件也是做了這件事),而且還要記得結束后再手工移除。

BrowserSync的一般用法則不需要瀏覽器插件,也不用手工添加代碼(盡管也提供那樣的用法)。一句控制臺的命令之后,無論是在手機里還是電腦,無論用多少個瀏覽器(經測試,IE8+及其它),都可以擁有自動刷新的功能。

BrowserSync是怎么做到的?請看它的安裝及使用。

安裝及使用

安裝Node后,通過npm安裝BrowserSync:

npm install -g browser-sync

然后,就可以開始使用了。打開控制臺進入項目所在的目錄,然后輸入像這樣的命令:

browser-sync start --server --files "css/*.css"

這個命令用于純靜態站點,也就是僅一些.html文件的情況。后面的--files "css/*.css",是指監聽css目錄中的后綴名為.css的文件。請注意這個命令里的start --server,這其實是BrowserSync自己啟動了一個小型服務器。

如果是動態站點,則使用代理模式。例如PHP站點,已經建立了一個本地服務器如http://localhost:8080,此時會是這樣的命令:

browser-sync start --proxy "localhost:8080" --files "css/*.css"

BrowserSync會提供一個新地址(如未被占用的話,http://localhost:3000)用于訪問。

好了,為什么BrowserSync不需要瀏覽器插件?因為它使用了服務器的形式(直接或代理)來處理項目文件。默認情況下,訪問它的服務器上的網頁,可以看到這樣的提示簽:

hint tag: Connected to BrowserSync

這說明當前瀏覽的網頁已連接到BrowserSync。查看一下源碼,會發現它們都被添加了與BrowserSync有關的一段<script>代碼,就像LiveReload瀏覽器插件做的那樣。這些代碼會在瀏覽器和BrowserSync的服務器之間建立web socket連接,一旦有監聽的文件發生變化,BrowserSync會通知瀏覽器。

如果發生變化的文件是css,BrowserSync不會刷新整頁,而是直接重新請求這個css文件,并更新到當前頁中,效果像這樣:

顯然,這感覺更加快捷。如果你正在開發的是一個單頁應用(SPA),刷新整頁會回到初始視圖,而你又需要修改后面的某一個視圖時,這一功能尤其有用。

文件匹配

從BrowserSync的命令來看,很重要的一點就是通過--files指定需要監聽的文件。有關這里的文件匹配模式(稱為glob)的詳情,請參考isaacs's minimatch。

經過我自己的嘗試,如果簡單只是想要監聽整個項目,可以寫成這樣:

browser-sync start --server  --files "**"

此時,BrowserSync仍然會正確地判斷文件變化是否是css。

加入到Gulp使用

Gulp是現在流行的自動化工具,但BrowserSync并沒有Gulp插件版,因為并不需要。BrowserSync有自己獨立的API,將它注冊為gulp的一個task即可。下面是一段gulpfile.js的示例:

var gulp = require('gulp');var browserSync = require('browser-sync');gulp.task('browser-sync', function() { browserSync({ files: "**", server: { baseDir: "./" } });});gulp.task('default', ["browser-sync"]);

這時候運行gulp將等同于前文的browser-sync start --server --files "**"。更多的用法示例請查看gulp-browser-sync。

完整選項

到此為止,介紹的都是BrowserSync的基本用法。在控制臺里嘗試只輸入:

browser-sync

你會看到BrowserSync完整的控制臺命令指南。其中可以看到有這個命令:

browser-sync init

運行它,將在當前目錄生成一個配置文件bs-config.js。

參照官方文檔修改這個文件,然后運行

browser-sync start --config bs-config .js

就將以bs-config.js的完整配置信息運行BrowserSync。

不只是自動刷新

BrowserSync并不只是一個自動刷新工具,它還有許多其他功能。默認配置下,BrowserSync會在多個瀏覽器中同步滾動條位置,表單行為和點擊事件。例如,表單行為的情形像這樣:

我覺得這是很酷的功能!想象一下桌上擺很多個不同屏幕尺寸的手機來測試的情景,你操作一個,就會帶動其他的一起!當然,這些功能還可以在不需要的時候關閉。

UI界面及其他
下面是一個BrowserSync的控制臺輸出示例:

可以看到還有一個叫做UI的一個地址,它是BrowserSync提供的一個簡易控制面板。BrowserSync最常用的幾個配置選項,都可以在這個面板里調整。

在面板里面你還會發現那個經典的遠程調試工具weinre也在這:

BrowserSync目前已知的一點問題

前文提到,如果發生變化的文件是css,BrowserSync會以無刷新方式來更新,這是一個很棒的效果。如果使用scss、less等預編譯器,將監聽設置為編譯后的css文件即可。

但是,Web應用框架Rails會有一些問題。在開發環境中,css是在被請求的時候編譯(Rails一般使用sass)再返回給瀏覽器的,它只有緩存,而沒有實際的.css文件。因此,BrowserSync的文件監聽將無法指向它們,而如果指向sass文件,瀏覽器只會以整頁刷新的形式來處理。這個問題可以參見Github上的issue。

一個可行的解決方法是用其他工具替代Rails的Asset Pipeline。但在這里,我推薦另一個解決方案:使用LiveReload(LiveReload你還是有點水平的?。?。經測試,LiveReload在Rails中也可以處理好css的快捷更新。關于LiveReload做到這一點的原理,你可以閱讀Lightning-Fast Sass Reloading in Rails。

也期待BrowserSync可以在未來解決這個問題。

結語

想要在開發中更流暢,更快捷?請嘗試BrowserSync!節約一點時間,你也許就可以做到更多。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人免费自拍视频| 成人黄色免费看| 国产在线播放不卡| 51色欧美片视频在线观看| 免费av一区二区| 国产欧美最新羞羞视频在线观看| 毛片精品免费在线观看| 欧美成年人视频网站欧美| 97色在线观看免费视频| 97久久伊人激情网| 热re91久久精品国99热蜜臀| 欧美在线性视频| 亚洲国产黄色片| 亚洲美女视频网站| 国产精品在线看| 国产综合在线视频| 欧美xxxx14xxxxx性爽| 久久久亚洲影院你懂的| 国产日韩欧美另类| 日韩第一页在线| 国产主播在线一区| 在线看欧美日韩| 中文字幕日韩av电影| 久久亚洲国产精品| 国产精品黄色av| 性欧美办公室18xxxxhd| 日韩激情av在线播放| 国产精品扒开腿做爽爽爽视频| 亚洲第一精品自拍| 亚洲精品在线视频| 欧美剧在线观看| 亚洲自拍偷拍网址| 在线日韩欧美视频| 国产精欧美一区二区三区| www.日本久久久久com.| 久久最新资源网| 91精品在线一区| 欧美黄色成人网| 欧美极品美女视频网站在线观看免费| 国外成人在线直播| 久热爱精品视频线路一| 在线亚洲男人天堂| 欧美成人中文字幕| 国产婷婷色综合av蜜臀av| 国产成人精品网站| 狠狠色狠狠色综合日日小说| 国产精品jvid在线观看蜜臀| 日韩精品一区二区三区第95| 国产精品免费一区豆花| 91精品国产乱码久久久久久蜜臀| 日韩欧美国产免费播放| 国语自产偷拍精品视频偷| 欧美三级欧美成人高清www| 美女撒尿一区二区三区| 中文日韩在线视频| 黑人巨大精品欧美一区二区一视频| 国产精品一二三在线| 欧美亚州一区二区三区| 日本久久久久久久久| 亚洲电影av在线| 欧美福利视频在线| 精品无码久久久久久国产| 久精品免费视频| 国产精品1区2区在线观看| 中文.日本.精品| 欧美黄网免费在线观看| 国产一区二区在线免费| 欧美精品18videos性欧| 78m国产成人精品视频| 欧美日韩国产一区二区三区| 日本午夜人人精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲男人的天堂在线播放| 亚洲女人被黑人巨大进入| 亚洲深夜福利在线| 久久精品国产96久久久香蕉| 久久青草福利网站| 欧美第一黄色网| 国产成人精品久久二区二区| 国产一区香蕉久久| 美女久久久久久久| 精品国模在线视频| 日韩在线高清视频| 亚洲a在线播放| 一本一本久久a久久精品牛牛影视| 日韩综合视频在线观看| 欧美精品免费在线| 欧美激情伊人电影| 亚洲视频在线观看免费| 日韩视频中文字幕| 日韩欧美亚洲综合| 国产精品人成电影| 亚洲精品国产成人| 欧美激情精品久久久久久免费印度| 性色av一区二区三区红粉影视| 久久亚洲精品中文字幕冲田杏梨| 欧美亚洲免费电影| 精品国模在线视频| 亚洲电影免费观看高清完整版在线| 热门国产精品亚洲第一区在线| 97视频在线观看视频免费视频| 91社区国产高清| 亚洲男人天天操| 日韩在线视频免费观看高清中文| 国产精品欧美日韩一区二区| 亚洲国产天堂久久综合| 欧美日韩国产999| 亚洲欧美激情精品一区二区| 91豆花精品一区| 日韩二区三区在线| 亚洲午夜色婷婷在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产成人精品999| 中文字幕久精品免费视频| 亚洲日韩欧美视频一区| 欧美激情免费看| 另类天堂视频在线观看| 欧美成人午夜剧场免费观看| 亚洲女人被黑人巨大进入al| 7777精品视频| 日韩欧美黄色动漫| 日韩精品在线观看一区二区| 在线观看免费高清视频97| 亚洲成av人乱码色午夜| 国产精品高精视频免费| 欧美日韩国产综合视频在线观看中文| 亚洲aa中文字幕| 欧美激情aaaa| 高清在线视频日韩欧美| 538国产精品一区二区免费视频| 国内精品久久久久伊人av| 成人免费在线视频网址| 国产不卡av在线免费观看| 亚洲偷欧美偷国内偷| 亚洲国产成人久久综合| 国产成人免费91av在线| 欧美电影《睫毛膏》| 懂色aⅴ精品一区二区三区蜜月| 欧美大人香蕉在线| 欧美乱妇40p| 欧美日韩xxx| 一级做a爰片久久毛片美女图片| xvideos国产精品| 66m—66摸成人免费视频| 97在线视频免费| 欧美成年人网站| 在线a欧美视频| 日韩中文字幕久久| 欧美成人性色生活仑片| 成人国产亚洲精品a区天堂华泰| 热99久久精品| 亚洲护士老师的毛茸茸最新章节| 亚洲国内高清视频| 久久国产视频网站| 亚洲综合社区网| 全球成人中文在线| 庆余年2免费日韩剧观看大牛| 欧美激情一级二级| 亚洲变态欧美另类捆绑| 亚洲影视中文字幕| 91精品视频在线播放| 久久艹在线视频| 18久久久久久| 日韩成人av在线播放|