校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 自動刷新從BrowserSync開始

自動刷新從BrowserSync開始

熱門標簽:天津電銷卡外呼系統線路 興化400電話辦理多少錢 靈聲智能電話機器人招聘 智能電銷機器人真的好嗎 株洲外呼營銷系統有哪些 企業電話機器人辦理 四平電話機器人哪家好 長春銷售外呼系統業務 長春防封卡電銷卡套餐

請想象這樣一個場面:你開著兩個顯示器,一邊是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!節約一點時間,你也許就可以做到更多。

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

您可能感興趣的文章:
  • 如何使用Linux的rsync
  • Rsync 秒殺一切備份工具,你能手動屏蔽某些目錄嗎?
  • Linux 通過Rsync+Inotify實現本、異地遠程數據實時同步功能
  • python rsync服務器之間文件夾同步腳本
  • python+rsync精確同步指定格式文件
  • centos7下rsync+crontab定期同步備份
  • Linux下使用Rsync完成自動化備份
  • Java之Rsync并發遷移數據并校驗詳解

標簽:漯河 新疆 黑龍江 石嘴山 巴彥淖爾 青海 貴港 運城

巨人網絡通訊聲明:本文標題《自動刷新從BrowserSync開始》,本文關鍵詞  自動,刷新,從,BrowserSync,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《自動刷新從BrowserSync開始》相關的同類信息!
  • 本頁收集關于自動刷新從BrowserSync開始的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美一区二区福利视频| 欧美亚州韩日在线看免费版国语版| 亚洲一级不卡视频| 国产精品久久毛片| 成人欧美一区二区三区白人| 中文一区一区三区高中清不卡| 欧美精品在线一区二区| 欧美日韩国产在线观看| 欧美精品一二三区| 日韩免费一区二区| 国产人成一区二区三区影院| 久久久影视传媒| 自拍偷拍欧美激情| 亚洲国产美女搞黄色| 日产欧产美韩系列久久99| 久久精品国产99| 成人看片黄a免费看在线| 91麻豆.com| 7777精品久久久大香线蕉| 日韩精品中文字幕在线不卡尤物| 日韩精品一区二区三区在线观看 | 国产原创一区二区| 成人免费看黄yyy456| 欧洲另类一二三四区| 91精品国产综合久久福利软件| 日韩美女在线视频| 国产精品国产三级国产普通话蜜臀| 亚洲欧美日韩人成在线播放| 性欧美疯狂xxxxbbbb| 美女国产一区二区| 色婷婷亚洲精品| 欧美成人一级视频| 亚洲一二三四区不卡| 极品少妇一区二区三区精品视频| 成人精品国产一区二区4080| 欧美午夜片在线观看| 精品88久久久久88久久久| 亚洲精品视频免费观看| 国精产品一区一区三区mba桃花 | 亚洲精品国产第一综合99久久 | 久久精品国产99国产精品| 成人性生交大片免费看中文 | 日韩精品最新网址| 悠悠色在线精品| 国产69精品久久久久毛片| 欧美高清激情brazzers| 国产精品久久久久精k8| 极品美女销魂一区二区三区免费| 色综合天天狠狠| 久久精品视频一区二区| 日韩国产高清影视| 91福利在线导航| 成人欧美一区二区三区黑人麻豆 | 韩国视频一区二区| 在线综合视频播放| 亚洲自拍偷拍欧美| 99国产精品99久久久久久| 久久蜜桃香蕉精品一区二区三区| 玉米视频成人免费看| 不卡欧美aaaaa| 国产午夜精品一区二区三区嫩草| 另类欧美日韩国产在线| 欧美日韩国产首页在线观看| 国产精品久久久久婷婷| 国产乱人伦精品一区二区在线观看| 欧美片网站yy| 午夜精品在线看| 欧美色视频在线| 亚洲一区二区三区四区五区黄| 不卡的av网站| 有坂深雪av一区二区精品| 欧美性做爰猛烈叫床潮| 亚洲影视在线观看| 欧洲生活片亚洲生活在线观看| 亚洲精选一二三| 欧美日韩精品一区二区三区| 亚洲综合一区在线| 欧美日韩美女一区二区| 亚洲3atv精品一区二区三区| 欧美日韩一区二区在线观看 | 国产伦精品一区二区三区视频青涩| 欧美一区二区久久| 蜜臀国产一区二区三区在线播放| 欧美精品高清视频| 免费成人美女在线观看.| 日韩欧美国产一区二区在线播放| 美女网站色91| 国产精品美女一区二区在线观看| 成人高清av在线| 亚洲一级不卡视频| 精品精品国产高清a毛片牛牛| 久久精品av麻豆的观看方式| 精品成a人在线观看| 波多野结衣亚洲| 亚洲综合男人的天堂| 欧美成人免费网站| 成人国产视频在线观看| 亚洲午夜在线观看视频在线| 91精品国产一区二区三区 | 一本色道久久加勒比精品| 亚洲一本大道在线| 日韩精品一区二区三区在线播放 | 国产在线日韩欧美| 国产精品久久久久久久第一福利| 97se亚洲国产综合自在线观| 亚洲超碰精品一区二区| 26uuuu精品一区二区| 99久久久国产精品免费蜜臀| 亚洲午夜在线视频| 久久久91精品国产一区二区精品 | 亚洲福中文字幕伊人影院| 欧美变态口味重另类| 色综合天天综合网国产成人综合天| 亚洲va欧美va人人爽午夜| 2023国产精品视频| 欧美视频日韩视频| 成人国产亚洲欧美成人综合网| 日日夜夜精品免费视频| ㊣最新国产の精品bt伙计久久| 欧美日韩国产一区| av影院午夜一区| 韩国三级中文字幕hd久久精品| 亚洲精品久久久蜜桃| 久久精品日产第一区二区三区高清版| 欧美色偷偷大香| a级精品国产片在线观看| 久热成人在线视频| 五月天激情小说综合| 亚洲欧美一区二区视频| 久久精品视频在线免费观看| 欧美日韩成人在线| 一本到不卡精品视频在线观看| 极品美女销魂一区二区三区| 亚洲国产三级在线| 亚洲精品va在线观看| 亚洲天堂网中文字| 1区2区3区国产精品| 久久久久久亚洲综合| 欧美变态口味重另类| 91精品欧美福利在线观看| 欧美三级电影精品| 在线免费不卡视频| 欧美在线啊v一区| 91久久香蕉国产日韩欧美9色| 北条麻妃一区二区三区| 国产成+人+日韩+欧美+亚洲 | 国产精品不卡视频| 国产无遮挡一区二区三区毛片日本| 欧美成人福利视频| 日韩视频一区二区三区在线播放| 欧美日韩国产在线观看| 欧美日韩国产美女| 日韩精品一区二区在线| 欧美成人午夜电影| 久久综合五月天婷婷伊人| www国产精品av| 国产视频一区不卡| 中文字幕乱码日本亚洲一区二区| 久久久久久久久久美女| 久久精品一区二区三区av| 国产日韩欧美综合一区| 欧美极品另类videosde| 国产精品剧情在线亚洲| 亚洲男女毛片无遮挡| 亚洲一区二区三区三| 性做久久久久久免费观看欧美| 亚洲第一成人在线| 久久99精品国产麻豆婷婷| 国产精品自在在线| hitomi一区二区三区精品| 在线免费不卡视频| 日韩欧美中文字幕制服| 中文成人综合网| 一区二区三区丝袜| 青青草成人在线观看| 国产真实乱子伦精品视频| 成人禁用看黄a在线| 欧美日韩成人一区二区| 久久亚洲一区二区三区四区| 国产精品每日更新| 奇米在线7777在线精品| 国产精品88888| 在线免费观看日韩欧美| 欧美va亚洲va| 洋洋av久久久久久久一区| 免费观看91视频大全| www.爱久久.com| 欧美高清视频在线高清观看mv色露露十八 | 国产区在线观看成人精品| 亚洲精品视频在线观看免费| 美女爽到高潮91| 色哟哟国产精品| 26uuu欧美| 天堂一区二区在线| 粉嫩13p一区二区三区| 宅男在线国产精品| 亚洲三级免费观看| 国产制服丝袜一区| 欧美高清激情brazzers| 最近日韩中文字幕|