一、響應式佈局html
參考:https://www.ui.cn/detail/351448.html前端
簡而言之,就是一個網站可以兼容多個設備終端,它能夠自動識別設備尺寸並相應調整佈局,而不是爲每一個終端作一個特定的版本。隨着愈來愈多智能移動設備的誕生,小到智能手錶,大到4k顯示屏,「主流設備」的概念正在慢慢消失,就算是PC和MAC咱們也不能肯定用戶的瀏覽窗口有多大(有調研只有一半的用戶會全屏顯示瀏覽器),爲了給不一樣終端的用戶提供更加溫馨的界面和用戶體驗,響應式設計應時而生。html5
對頁面進行響應式設計,須要對相同的內容進行不一樣寬度的佈局設計。首先要根據目標用戶和使用環境等定位考慮側重的是桌面端仍是移動端:桌面優先(從桌面端開始向下設計);移動優先(從移動端開始向上設計)。由於須要適應不一樣的尺寸,對樣式上有較大的侷限性,在各類因素的影響下讓頁面達不到最佳的效果,因此須要根據用戶羣和使用環境來考慮側重哪一種設備,儘可能爲最中心的用戶提供最優的體驗。不管基於哪一種方向開始設計,要適配全部的設備,頁面模塊不可避免的須要隨着設備尺寸作相應的改變。當頁面寬度發生變化,超過了制定範圍的臨界點,頁面樣式就會發生變化,這個範圍咱們叫作斷點區間。Bootstrap是全球最受歡迎的前端組件庫,用於開發響應式佈局、移動設備優先的 WEB 項目。java
響應式佈局樣式常見的有5種:1.擠壓-拉伸、2.上下-左右、3.刪減-增長、4.變換位置、5.隱藏-展開jquery
總結:ios
不少時候單一的佈局方式沒法達到最好的效果,須要根據實際的狀況,搭配靈活使用;適配移動端時,根據頁面的功能主次作減法,不要爲了保留全部內容讓頁面冗長,可讀性差,認知難度增大;移動端是沒有hover效果的,要考慮移動端的操做習慣(好比:桌面端hover內容就能出現的說明,移動端可能須要提醒+彈出,或者直接顯示出來);設計稿上的字體與用戶實際看到的字體是有差異的,特別是適配移動端(使用電腦、電視與手機之間的距離不同、分辨率也不同,字體大小需求也會不同。好比雖然電視屏幕大,可是距離較遠,桌面端的字體大小在電視上可讀性會不好;電腦上最小的字體是12px,可是在移動端時12px很是小)。ajax
不管從手機端開始設計,仍是電腦端,在作的過程當中,要考慮發生變化之後頁面總體的樣式。相同設備的交互邏輯保持統一,好比平板與手機(手勢操做),寬屏顯示器與lapto(鼠標操做、觸屏操做)。並且要考慮這兩種不一樣的使用環境以及移動端和pc端用戶的使用習慣。算法
二、圖片上傳(兼容ie8和ie9)數據庫
參考:https://www.jianshu.com/p/b2ab1eb2452ejson
https://developer.mozilla.org/zh-CN/docs/Web/API/FormData
1)若是不考慮ie9兼容性,能夠經過ajax和FormData上傳圖片。FormData 是 XMLHttpRequest Level 2 新增的接口,低於IE10 的IE瀏覽器不支持該接口,也不支持html5表單上傳控件Files API(e.target.files爲undefined)。
2)爲了兼容低於IE10 的IE瀏覽器,可經過form表單形式實現圖片上傳。
<form id="file-form" method="post" action="xxx" enctype="multipart/form-data"> <label class="upload-select"> <i class="add-icon"></i> <p class="upload-text">點擊添加圖片</p> <input type="file" accept=".jpg, .gif, .png" class="input-file" name="Filedata"> </label> </form>
表單中enctype="multipart/form-data"的意思,是設置表單的MIME編碼。默認狀況,這個編碼格式是application/x-www-form-urlencoded,不能用於文件上傳;只有使用了multipart/form- data,才能完整的傳遞文件數據。
enctype 屬性規定在發送到服務器以前應該如何對錶單數據進行編碼。
$('.input-file').change(function() { $('#file-form').submit(); // 觸發提交表單 submit 事件 }); $('#file-form').submit(function() { // 將函數綁定到 submit 事件 $('#file-form').ajaxSubmit(function(data) { }); return false; // 阻止頁面跳轉 });
ajaxSubmit方法是jQuery的一個插件jquery.form.js裏面的方法,因此使用此方法須要先引入這個插件,它是一個form插件,支持ajax表單提交和ajax文件上傳。一般狀況下,咱們直接經過form提交的話, 提交後當前頁面跳轉到form的action所指向的頁面。然而,不少時候咱們比不但願提交表單後頁面跳轉,那麼,咱們就可使用ajaxSubmit來提交數據。
此時,若是服務器返回的是json對象,在ie8和ie9下並不能拿到服務器返回的數據,而是直接提示下載或打開(圖片上傳成功),以下圖所示
解決方案:服務端返回json字符串,前臺轉成json對象,而後進行接下來的處理,展現上傳的圖片等。
$('#file-form').submit(function() { $(this).ajaxSubmit({ success: function(data) { data = JSON.parse(data); console.log(data); }, error: function() { globalFn.showToast({title: '圖片上傳失敗'}); } }); return false; });
三、flex:1;
參考:https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex
CSS屬性flex
規定了彈性元素如何伸長或縮短以適應flex容器中的可用空間。這是一個簡寫屬性,用來設置
flex-grow
, flex-shrink
與flex-basis
。
設置min-width,可避免flex 元素在默認寬度之和大於容器的時候發生收縮(CSS flex-shrink 屬性)。
四、前端複製到剪切板
$('body').on('click', '.copy-btn', function () { $(this).siblings('.code-input')[0].select(); // 選中文本 document.execCommand("copy"); // 拷貝當前選中內容到剪貼板 weui.toast('複製成功'); });
此方式兼容ie8,移動端安卓也支持,可是iOS不支持。
解決方案:使用插件clipboard.js
參考:https://blog.csdn.net/sinat_34351851/article/details/82627198
1)頁面引入clipboard.min.js(我使用的版本是v2.0.4)
2)html
能夠從input、textarea、div等元素中獲取目標內容,data-clipboard-target指向目標節點(被複制/剪切,匹配選擇器)。data-clipboard-action可使用copy和cut,使用cut則點擊按鈕後,內容裏的值被剪切。若是沒有指定,則默認值是copy。cut只對input和textarea起做用。
<!-- Target --> <textarea id="bar">Mussum ipsum cacilds...</textarea> <!-- Trigger --> <button class="btn" data-clipboard-action="cut" data-clipboard-target="#bar">Cut to clipboard</button>
3)js
var clipboard = new ClipboardJS('.copy-btn'); clipboard.on('success', function(e) { // 成功回調 weui.toast('複製成功'); }); clipboard.on('error', function(e) { // 失敗回調 console.log(e); });
五、weui
調出對話框:
weui.confirm('請使用購買商品時填寫的手機號進行登陸而後查看卡密詳情,從新登陸?', { title: '提示', buttons: [{ label: '取消', type: 'default', onClick: function(){} }, { label: '肯定', type: 'primary', onClick: function(){ location.href = '/h5/login.html'; } }] });
調整對話框樣式:
.weui-dialog { width: 85%; max-width: 500px; } .weui-dialog__title, .weui-dialog__btn { font-size: 24px !important; } .weui-dialog__bd { font-size: 22px !important; }
瀏覽器渲染:
ios:
安卓:
六、document.referrer
返回跳轉或打開到當前頁面的那個頁面的URI。若是用戶直接打開了這個頁面(不是經過頁面跳轉,而是經過地址欄或者書籤等打開的),則該屬性爲空字符串。
返回上一頁,可使用history.go(-1)
或者history.back()【使用這兩種方式返回上一個頁面在移動端不會刷新頁面?】
解決方案:location.href = document.referrer(返回並刷新上一個頁面)
七、Safari瀏覽器
參考:https://blog.csdn.net/u011627980/article/details/79643428
對於先後端分離的項目或者單點登陸的系統後臺須要作session會話校驗或者cookie跨域存儲,Safari瀏覽器可能會遇到沒法存儲cookie,須要關閉瀏覽器的「阻止跨(網)站跟蹤」開關。
參考:https://blog.csdn.net/JamieCheung/article/details/80175591
Navigator 對象包含有關瀏覽器的信息。
能夠利用navigator.vendor字段來判斷是不是Safari瀏覽器,navigator.vendor字段是描述瀏覽器提供商的字段,在Safari下爲「Apple Computer, Inc.」
pc端判斷方法:/Apple/.test(navigator.vendor)。
可是這個字段僅僅適合判斷是不是Safari,並且僅適合在PC上判斷。在ios手機上,我經過alert(navigator.vendor);測試,不管是不是safari瀏覽器,都彈框「Apple Computer, Inc.」
手機端判斷方法:/Safari/.test(navigator.userAgent) && !/Chrome/.test(navigator.userAgent);【測試了ios上的safari瀏覽器和非safari瀏覽器和安卓上的瀏覽器,結果safari瀏覽器的navigator.userAgent字段包含Safari不包含Chrome,ios上的非safari瀏覽器不包含Safari和Chrome,安卓上的瀏覽器包含Safari和Chrome】
八、單點登陸
單點登陸(Single Sign On),簡稱爲 SSO,是目前比較流行的企業業務整合的解決方案之一。SSO的定義是在多個應用系統中,用戶只須要登陸一次就能夠訪問全部相互信任的應用系統。
很早期的公司,一家公司可能只有一個Server,慢慢的Server開始變多了。每一個Server都要進行註冊登陸,退出的時候又要一個個退出。用戶體驗很很差!你能夠想象一下,上豆瓣 要登陸豆瓣FM、豆瓣讀書、豆瓣電影、豆瓣日記......真的會讓人崩潰的。咱們想要另外一種登陸體驗:一家企業下的服務只要一次註冊,登陸的時候只要一次登陸,退出的時候只要一次退出。
參考:https://yq.aliyun.com/articles/636281
如圖所示,圖中有4個系統,分別是Application一、Application二、Application三、和SSO。Application一、Application二、Application3沒有登陸模塊,而SSO只有登陸模塊,沒有其餘的業務模塊,當Application一、Application二、Application3須要登陸時,將跳到SSO系統,SSO系統完成登陸,其餘的應用系統也就隨之登陸了。
如上圖所示,咱們在瀏覽器(Browser)中訪問一個應用,這個應用須要登陸,咱們填寫完用戶名和密碼後,完成登陸認證。這時,咱們在這個用戶的session中標記登陸狀態爲yes(已登陸),同時在瀏覽器(Browser)中寫入Cookie,這個Cookie是這個用戶的惟一標識。下次咱們再訪問這個應用的時候,請求中會帶上這個Cookie,服務端會根據這個Cookie找到對應的session,經過session來判斷這個用戶是否登陸。若是不作特殊配置,這個Cookie的名字叫作jsessionid,值在服務端(server)是惟一的。
同域下的單點登陸是巧用了Cookie頂域的特性。若是是不一樣域呢?不一樣域之間Cookie是不共享的。
具體流程以下:
至此,跨域單點登陸就完成了。之後咱們再訪問app系統時,app就是登陸的。接下來,咱們再看看訪問app2系統時的流程。
這樣,app2系統不須要走登陸流程,就已是登陸了。SSO,app和app2在不一樣的域,它們之間的session不共享也是沒問題的。
補充: https://www.cnblogs.com/EzrealLiu/p/5559255.html
九、微信登陸
網站內嵌二維碼微信登陸JS代碼中href字段做用?
答:若是第三方以爲微信團隊提供的默認樣式與本身的頁面樣式不匹配,能夠本身提供樣式文件來覆蓋默認樣式,並把連接地址填入href字段
擴展:
iframe跨域:瀏覽器有一個同源策略,第一種限制就是不能經過ajax的方法去請求不一樣源的文檔。第二種限制是瀏覽器中不一樣域的框架之間是不能進行js的交互操做的。
十、h5頁面在手機上返回如何刷新頁面
var isPageHide =false; window.addEventListener('pageshow', function () { if (isPageHide) { window.location.reload(); } }); window.addEventListener('pagehide', function () { isPageHide =true; });
onpageshow 事件在用戶瀏覽網頁時觸發。onpageshow 事件相似於 onload 事件,onload 事件在頁面第一次加載時觸發, onpageshow 事件在每次加載頁面時觸發,即 onload 事件在頁面從瀏覽器緩存中讀取時不觸發。
onpagehide 事件在用戶離開網頁時觸發。離開網頁有多種方式。如點擊一個連接,刷新頁面,提交表單,關閉瀏覽器等。.onpagehide 事件有時能夠替代 onunload 事件,但 onunload 事件觸發後沒法緩存頁面。
十一、電商超賣及解決方案(事務鎖、樂觀鎖)
1)電商超賣
參考:https://blog.csdn.net/mydistance/article/details/85236410
超賣即「超賣缺貨」,當寶貝庫存接近0時,若是多個買家同時付款購買此寶貝,將會出現「超賣缺貨」現象。電商大促期間,隨着各類優惠促銷活動的刺激,訂單量會急速增加。隨着銷量的節節攀升,商品超賣問題也愈來愈嚴重,嚴重影響了商家的正常運營。
庫存會帶來「超賣」的問題:售出數量多於庫存數量。因爲庫存併發更新的問題,致使在實際庫存已經不足的狀況下,庫存依然在減,致使賣家的商品賣得件數超過秒殺的預期。
優化:
2)悲觀鎖和樂觀鎖
參考:https://www.imooc.com/article/details/id/44217
悲觀鎖:老是假設最壞的狀況,每次去拿數據的時候都認爲別人會修改,因此每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會阻塞直到它拿到鎖(共享資源每次只給一個線程使用,其它線程阻塞,用完後再把資源轉讓給其它線程)。傳統的關係型數據庫裏邊就用到了不少這種鎖機制,好比行鎖,表鎖等,讀鎖,寫鎖等,都是在作操做以前先上鎖。Java中synchronized
和ReentrantLock
等獨佔鎖就是悲觀鎖思想的實現。
樂觀鎖:老是假設最好的狀況,每次去拿數據的時候都認爲別人不會修改,因此不會上鎖,可是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據,可使用版本號機制和CAS算法實現。樂觀鎖適用於多讀的應用類型,這樣能夠提升吞吐量,像數據庫提供的相似於write_condition機制,其實都是提供的樂觀鎖。在Java中java.util.concurrent.atomic
包下面的原子變量類就是使用了樂觀鎖的一種實現方式CAS實現的。
樂觀鎖相對悲觀鎖而言,樂觀鎖機制採起了更加寬鬆的加鎖機制。悲觀鎖大多數狀況下依靠數據庫的鎖機制實現,以保證操做最大程度的獨佔性。但隨之而來的就是數據庫性能的大量開銷,特別是對長事務而言,這樣的開銷每每沒法承受。而樂觀鎖機制在必定程度上解決了這個問題。樂觀鎖,大可能是基於數據版本( Version )記錄機制實現。何謂數據版本?即爲數據增長一個版本標識,在基於數據庫表的版本解決方案中,通常是經過爲數據庫表增長一個 「version」 字段來實現。讀取出數據時,將此版本號一同讀出,以後更新時,對此版本號加一。此時,將提交數據的版本數據與數據庫表對應記錄的當前版本信息進行比對,若是提交的數據版本號大於數據庫表當前版本號,則予以更新,不然認爲是過時數據。
兩種鎖的使用場景:兩種鎖各有優缺點,不可認爲一種好於另外一種,像樂觀鎖適用於寫比較少的狀況下(多讀場景),即衝突真的不多發生的時候,這樣能夠省去了鎖的開銷,加大了系統的整個吞吐量。但若是是多寫的狀況,通常會常常產生衝突,這就會致使上層應用會不斷的進行retry,這樣反卻是下降了性能,因此通常多寫的場景下用悲觀鎖就比較合適。
樂觀鎖常見的兩種實現方式:樂觀鎖通常會使用版本號機制或CAS算法實現。
CAS算法:即compare and swap(比較與交換),是一種有名的無鎖算法。
CAS算法的缺點:
用戶體驗(User Experience,簡稱UE/UX)
1)步驟型導引:將複雜的任務分解成有序的任務操做流,每一個簡化後的任務均可以快速完成,以幫助用戶順利完成總體任務。
綜合考慮用戶的易用性和情感化因素,過多的信息難以讓用戶聚焦,同時產生抵觸情緒,同時在校驗上也承載了極大的分險,由於數據越多,修改校驗後的錯誤信息的難度就越大。面對這種交互信息繁多的狀況,分步分解任務後,用戶只須要按着機器預置好的一系列步驟,每完成一步對於用戶情緒上會有成就感加成,同時聚焦每一頁關鍵任務,分步校驗,避免用戶挫敗感,高效完成表單的填寫。
在上圖中,金蝶雲蒼穹產品裏的出差類應用,原來的長單據填寫被拆解成三步填寫,下降決策成本與用戶風險,用戶只須要關注當前步驟的結果。該方法同時適用於PC端、移動端等各終端。對於移動端而言,須要時刻注意在錄入表單的場景中,鍵盤彈起後剩餘的界面空間,此時保證信息出如今界面上方,也是易用性的細節保證。