移動京東項目練習記錄

来源:https://www.cnblogs.com/bystander-ry/archive/2019/12/06/11993701.html
-Advertisement-
Play Games

移動京東項目練習記錄 1. 流式佈局與移動端適配的基本要求 2. 綁定事件的幾個方式 on 只能綁定一次事件,但是可以相容各種瀏覽器 addeventlistener 適合各種谷歌相關的瀏覽器,可以綁定多次事件 attachEvent 適合IE瀏覽器,可以多次綁定 但是裡面事件名有on eg:tou ...


移動京東項目練習記錄

  1. 流式佈局與移動端適配的基本要求

        /*流式佈局:就是百分比佈局,非固定像素,內容向兩側填充,理解成流動的佈局,稱為流式佈局*/
        /*視覺視窗:viewport,是移動端特有。這是一個虛擬的區域,承載網頁的。
          承載關係:瀏覽器---->viewport---->網頁
        */
        /*適配要求:
            1. 網頁寬度必須和瀏覽器保持一致(因為只要橫向不出現滾動條就好)
            2. 預設顯示的縮放比例和PC端保持(縮放比例為1.0時和網頁上一致)
            3. 不允許用戶自行縮放網頁(否則破壞了網頁的顯示方式)
            滿足這些要求達到了適配,國際上通用的適配方案,標準的移動端適配方案。
        */
         /*防止內容溢出  不出現滾動條  提供用戶體驗*/
                box-sizing: border-box;
     /*手機端的瀏覽器大多數都是使用webkit內核,故要這麼適配*/
     -webkit-box-sizing: border-box;
     /*點擊高亮效果的清除*/
     tap-highlight-color: transparent;
     -webkit-tap-highlight-color: transparent;
  2. 綁定事件的幾個方式

    • on 只能綁定一次事件,但是可以相容各種瀏覽器

    • addeventlistener 適合各種谷歌相關的瀏覽器,可以綁定多次事件

    • attachEvent 適合IE瀏覽器,可以多次綁定 但是裡面事件名有on

      eg:touch事件

                 var div=document.querySelector(".div1");
                 div.addEventListener("touchstart",function(){
                     console.log("start!")
                 });
                 div.addEventListener("touchmove",function(){
                     console.log("start move!")
                 });
                 div.addEventListener("touchend",function(){
                     console.log("end move!")
                 });  
  3. 關於觸摸事件的補充,註意幾個坐標的差異

    在每一個觸摸點中會記錄當前觸摸點的坐標 e.touches[0] 第一個觸摸點
    clientX clientY 基於瀏覽器視窗(視口)
    pageX pageY 基於頁面(視口)
    screenX screenY 基於屏幕

  4. 倒計時 設置時分秒

    var timeDown = function() {
    var time = 2 * 60 * 60;

    setInterval(function() {
     time--;//使用定時器,自動減時間,更新時間
     var h = Math.floor(time / 3600);//小時
     var m = Math.floor(time % 3600 / 60);//分鐘
     var s = time % 60;//秒
     var spans = document.querySelectorAll(" .all-time span");
     spans[0].innerHTML = Math.floor(h / 10);//向下取整得到十位數
     spans[1].innerHTML = Math.floor(h % 10);//取餘得到個位數
     spans[3].innerHTML = Math.floor(m / 10);
     spans[4].innerHTML = Math.floor(m % 10);
     spans[6].innerHTML = Math.floor(s / 10);
     spans[7].innerHTML = Math.floor(s % 10);
    }, 1000)
  5. 兩欄自適應

     </head>
     <body>
         <div class="box1">
         </div>
         <div class="box2">
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         我是內容我是內容我是內容我是內容我是內容我是內容我是內容
         </div>
         .box1{
                /*設置浮動和寬度*/
                 width: 100px;
                 height: 100px;
                 background-color: pink;
                 float: left;
             }
             .box2{
                 /*可以清楚浮動,可以讓自己絕對絕緣 bfc*/
                    /*不讓其他浮動元素影響自己*/
                /*不讓自己的浮動去影響別的元素*/
                 overflow:hidden;
             }

  6. 圖標的裁切提升響應面積

     a{
        width: 40px;
        height: 44px;
        padding: 12px 10px;
        position: absolute;
        top: 0;
        /*讓背景從內容開始平鋪*/
        background-origin: content-box;
        /*沒有做背景裁剪 背景圖預設就是從邊框顯示*/
        /*預設的就是
        border-box  邊框以外被裁剪掉
        padding-box 內邊距以外被裁剪掉
        content-box 內容以外被裁剪掉
        */
        background-clip: content-box;
    }
  7. 兩個盒子,設置上面盒子高度之後,在設置下麵盒子占據剩餘高度

    .jd_main{
        /*占滿剩餘的高度*/
        width: 100%;
        height: 100%;
        padding-top: 45px;
    }     
  8. 圖片下間隙的處理方法

        body{
            /*font-size: 0px;*/
        }
        /*img{
            display: block;
        }*/
        img{
            vertical-align: middle;
        }
  9. 實現一個盒子的居中,使用margin:0 auto ; 是在父容器中居中,因此要設置寬度。但是如果該盒子設置了定位,margin居中將不可用。

  10. 行內元素,只要設置行高和高度,使得文本水平垂直居中即可

  11. 關於選擇器加空格問題

    • 沒有加空格表示同級元素li.now

    • 當兩個選擇器之間有空格的情況下,代表的是子類選擇器

      .a .b{}
      /*代表的是a類的b子類 */
      <div class="a b"></div>
      /*.a.b{}兩個選擇器之間沒有空格的情況下,代表的是同時擁有兩個類名的標簽*/
  12. 清除浮動 (當子元素設置了float屬性之後,且父元素的高度和寬度沒有進行設置,而是由子元素支撐起來,則會導致父元素的高度塌陷(原本的height後來被置為0))

    即子元素要浮動,則其父元素就要清除浮動,否則子元素不在裡面。

    清除浮動的方式:

    • 在父元素內添加冗餘元素clear:both;
    • 在父元素中設置屬性overflow:hidden||auto
    • after 方法(偽元素選擇器的方法)
    .clearFix::before,
    .clearFix::after{
        content: "";
        display: block;
        visibility: hidden;
        height: 0;
        line-height: 0;
        clear: both;
    }

    13 . 設置精靈圖公共樣式,之後再為每個圖標單獨設置位置

    [class^="icon-"],[class*=" icon-"]{
        background-repeat: no-repeat;
        background-image: url("../images/sprites.png");
        background-size: 200px 200px;
    } ```

    14 . 偽元素可以替代一些span,用於設置小圖標,預設行內元素,要設置為block

    15 . 一些小細節

  • 設置h3不是粗體font-weight:normal
  • 包含多個內容使用div,比如裡面放多個span
  • 背景圖不需要設置位置就寫center
  • 設置浮動會轉化為塊級元素
  • a中有圖,設置為block,可不設置寬
  • a img 設置margin居中 設置寬度 設置block消除下邊距

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 之前我寫了一篇文章,分享了自己的項目中對於介面管理的方法。總結下來就是:定義介面文件--withAxios導出--調用介面方法。這樣實現了介面的統一管理和調用介面的語義化與簡單化。 根據在項目的使用,發現有以下問題需要優化: 根據以上問題,採用了以下解決方案: 通過代碼展示一下(React項目): ...
  • 例如 通過學生獲取學生所在學校信息,需要先查詢學生所在班級,再通過班級查詢所在學校信息。js代碼類似寫法如下: 寫了個類通過設置相關業務信號量來綁定觸發的方法,當信號變數改變時就會自動調用相應的方法,改進方法如下: flag 是個信號量設置對象,s.setFlag(flag, "canGetClas ...
  • JavaScript中的函數可以通過幾種方式創建,如下。 // 函數聲明 function getName() { return 'Michael' } // 函數表達式 const getName = function() { return 'Michael' } // 箭頭函數(同樣也是表達式) ...
  • 在vue項目中,假使我們在同一個路由下,只是改變路由後面的參數值,期望達到數據的更新。 getDetail()方法中會用到this.id這個參數,在同一頁面切換id的值,並不會觸發vue的聲明周期函數。 可以添加路由監聽: ...
  • 1、下拉框 下拉框選擇時,觸發事件的方法: 在 Ext.form.ComboBox 組件中新增 listeners 監聽事件 基本寫法為: listeners{'事件',function(){處理方法}} listeners:{ select:{ fn:function(combo,record,i ...
  • 根據 CSS Scroll Snap Module Level 1 規範,CSS 新增了一批能夠控制滾動的屬性,讓滾動能夠在僅僅通過 CSS 的控制下,得到許多原本需要 JS 腳本介入才能實現的美好交互。 Tips:本文截的一些 Gif 圖涉及容器滾動,效果不是很好,可以點進 Demo 里實際感受下 ...
  • 點擊操作 節點的方式 案例 案例1:點擊按鈕,設置p變色 節點的方式做 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>title</title> <style> div { width: 200px; he ...
  • 介紹 "Ayer" 是一個乾凈且優雅的Hexo主題,自帶響應式,載入速度很快,該有的功能都有,可配置項也很多,非常適合作為你的博客主題,主題內還附送了6張精美的高清壁紙。歡迎使用和Star支持,如果你在使用過程中有任何疑問或者建議,歡迎聯繫我! "項目地址" "效果預覽" "中文說明" 特性 乾凈且 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...