整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          html自學教程(二)html段落與文本格式化

          html 段落

          通過<p>標簽來創建段落(paragraph)

          <p>這是一個段落</p>

          瀏覽器會自動在段落的前后添加空格

          ●如果你希望在不產生一個新段落的情況下進行換行(新行),請使用<br>標簽

          <p>這是一個段落</p>

          <p>這是另一個段落</p>

          <p>這個段落<br>演示了換行的效果</p>

          ●<br>元素是一個空的html元素,它沒有結束標簽.效果如下:

          二 html文本格式化

          html使用標簽<b><i>對輸出的文本進行格式化,如:粗體(bold)和斜體(italic).這些html標簽被稱為格式化標簽

          <!doctype html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>愛你的阿平</title>

          </head>

          <body>

          <p><b>定義粗體文本</b></p>

          <p><em>定義著重文字</em></p>

          <p><i>定義斜體字</i></p>

          <p><small>定義小號字<small></p>

          <p><strong>定義重要的文本<strong></p>

          <p><sub>下標字</sub></p>

          <p><sup>上標字</sup></p>

          <p><ins>定義插入字</ins></p>

          <p><del>定義刪除字</del></p>

          </body>

          </html>

          結果如下:

          、所有的操作,都會即時在右側的文檔欄目中即時反饋顯示,左側顯示為 Markdown 文本編輯器,右側窗口為最終生成文檔

          2、對于開始不熟悉 Markdown 語法的新手,軟件提供了新手引導:在菜單欄里集成了很多常用操作,對于初學者,可以學習與 這種操作對應的語法;

          3、對同一功能的實現 MarkdownPad2 對不同程度的使用者提供了多種方式供選擇;

          4、軟件上方的ToolBar,一次點擊即可完成操作。

          5、而對于新手,在菜單欄的insert選項中提供了相關操作。

          6、對常用操作,在菜單中都提供了相應快捷鍵。如 MarkdownPad2 提供的網頁瀏覽模式:在 Tools-> Preview Markdown in Browser,使用對應的快捷鍵 F6, 可以減少查找時間。

          7、注意開啟Markdown的擴展模式。

          <u>注意:Markdown使用#、+、*等符號來標記, 符號后面必須跟上 至少1個 空格才有效!</u>

          Markdown的常用語法

          標題

          Markdown 標題支持兩種形式:

          1、用#標記

          標題開頭 加上1~6個#,依次代表一級標題、二級標題....六級標題

          # 一級標題

          ## 二級標題

          ### 三級標題

          ##### 四級標題

          ###### 五級標題

          ###### 六級標題

          2、用=和-標記

          標題底下 加上任意個=代表一級標題,-代表二級標題

          一級標題

          ======

          二級標題

          ----------

          效果

          一陣做需求時,有個小功能實現起來廢了點腦細胞,覺得可以記錄一下。

          產品的具體訴求是:用戶點擊按鈕進入詳情頁面,詳情頁內的卡片標題內容過長時,標題的前后兩端正常展示,中間用省略號...表示,并且鼠標懸浮后,展示全部內容。

          關于鼠標懸浮展示全部內容的代碼就不放在這里了,本文主要寫關于實現中間省略號...的代碼。

          實現思路

          1. 獲取標題盒子的真實寬度, 我這里用的是clientWidth;
          2. 獲取文本內容所占的實際寬度;
          3. 根據文字的大小計算出每個文字所占的寬度;
          4. 判斷文本內容的實際寬度是否超出了標題盒子的寬度;
          5. 通過文字所占的寬度累加之和與標題盒子的寬度做對比,計算出要截取位置的索引;
          6. 同理,文本尾部的內容需要翻轉一下,然后計算索引,截取完之后再翻轉回來;

          代碼

          html代碼

          <div class="title" id="test">近日,銀行紛紛下調大額存單利率,但銀行定期存款仍被瘋搶。銀行理財經理表示:有意向購買定期存款要盡快,不確定利率是否會再降。</div>
          


          css代碼: 設置文本不換行,同時設置overflow:hidden讓文本溢出盒子隱藏

          .title {
              width: 640px;
              height: 40px;
              line-height: 40px;
              font-size: 14px;
              color: #00b388;
              border: 1px solid #ddd;
              overflow: hidden;
              /* text-overflow: ellipsis; */
              white-space: nowrap;
              /* box-sizing: border-box; */
              padding: 0 10px;
          }
          


          javascript代碼:

          獲取標題盒子的寬度時要注意,如果在css樣式代碼中設置了padding, 就需要獲取標題盒子的左右padding值。 通過getComputedStyle屬性獲取到所有的css樣式屬性對應的值, 由于獲取的padding值都是帶具體像素單位的,比如: px,可以用parseInt特殊處理一下。

          獲取盒子的寬度的代碼,我當時開發時是用canvas計算的,但計算的效果不太理想,后來逛社區,發現了嘉琪coder大佬分享的文章,我這里就直接把代碼搬過來用吧, 想了解的掘友可以直接滑到文章末尾查看。

          判斷文本內容是否超出標題盒子

           // 標題盒子dom
          const dom = document.getElementById('test');
          
          // 獲取dom元素的padding值
          function getPadding(el) {
              const domCss = window.getComputedStyle(el, null);
              const pl = Number.parseInt(domCss.paddingLeft, 10) || 0;
              const pr = Number.parseInt(domCss.paddingRight, 10) || 0;
              console.log('padding-left:', pl, 'padding-right:', pr);
              return {
                  left: pl,
                  right: pr
              }
          }
          // 檢測dom元素的寬度,
          function checkLength(dom) {
               // 創建一個 Range 對象
              const range = document.createRange();
              
              // 設置選中文本的起始和結束位置
              range.setStart(dom, 0),
              range.setEnd(dom, dom.childNodes.length);
              
              // 獲取元素在文檔中的位置和大小信息,這里直接獲取的元素的寬度
              let rangeWidth = range.getBoundingClientRect().width;
              
              // 獲取的寬度一般都會有多位小數點,判斷如果小于0.001的就直接舍掉
              const offsetWidth = rangeWidth - Math.floor(rangeWidth);
              if (offsetWidth < 0.001) {
                  rangeWidth = Math.floor(rangeWidth);
              }
              
              // 獲取元素padding值
              const { left, right } = getPadding(dom);
              const paddingWidth = left + right;
              
              // status:文本內容是否超出標題盒子;
              // width: 標題盒子真實能夠容納文本內容的寬度
              return {
                  status: paddingWidth + rangeWidth > dom.clientWidth,
                  width: dom.clientWidth - paddingWidth
              };
          }
          


          通過charCodeAt返回指定位置的字符的Unicode編碼, 返回的值對應ASCII碼表對應的值,0-127包含了常用的英文、數字、符號等,這些都是占一個字節長度的字符,而大于127的為占兩個字節長度的字符。

          截取和計算文本長度

          js// 計算文本長度,當長度之和大于等于dom元素的寬度后,返回當前文字所在的索引,截取時會用到。
          function calcTextLength(text, width) {
              let realLength = 0;
              let index = 0;
              for (let i = 0; i < text.length; i++) {
                  charCode = text.charCodeAt(i);
                  if (charCode >= 0 && charCode <= 128) {
                      realLength += 1;
                  } else {
                      realLength += 2 * 14; // 14是字體大小
                  }
                  // 判斷長度,為true時終止循環,記錄索引并返回
                  if (realLength >= width) {
                      index = i;
                      break;
                  }
              }
              return index;
          }
          
          // 設置文本內容
          function setTextContent(text) {
              const { status, width } = checkLength(dom);
              let str = '';
              if (status) {
                  // 翻轉文本
                  let reverseStr = text.split('').reverse().join('');
                  
                  // 計算左右兩邊文本要截取的字符索引
                  const leftTextIndex = calcTextLength(text, width);
                  const rightTextIndex = calcTextLength(reverseStr, width);
                  
                  // 將右側字符先截取,后翻轉
                  reverseStr = reverseStr.substring(0, rightTextIndex);
                  reverseStr = reverseStr.split('').reverse().join('');
                  
                  // 字符拼接
                  str = `${text.substring(0, leftTextIndex)}...${reverseStr}`;
              } else {
                  str = text;
              }
              dom.innerHTML = str;
          }
          


          最終實現的效果如下:

          上面就是此功能的所有代碼了,如果想要在本地試驗的話,可以在本地新建一個html文件,復制上面代碼就可以了。

          下面記錄下從社區內學到的相關知識:

          1. js判斷文字被溢出隱藏的幾種方法;
          2. JS獲取字符串長度的幾種常用方法,漢字算兩個字節;

          1、 js判斷文字被溢出隱藏的幾種方法

          1. Element-plus這個UI框架中的表格組件實現的方案。

          通過document.createRange和document.getBoundingClientRect()這兩個方法實現的。也就是我上面代碼中實現的checkLength方法。

          2. 創建一個隱藏的div模擬實際寬度

          通過創建一個不會在頁面顯示出來的dom元素,然后把文本內容設置進去,真實的文本長度與標題盒子比較寬度,判斷是否被溢出隱藏了。

          function getDomDivWidth(dom) {
              const elementWidth = dom.clientWidth;
              const tempElement = document.createElement('div');
              const style = window.getComputedStyle(dom, null)
              const { left, right } = getPadding(dom); // 這里我寫的有點重復了,可以優化
              tempElement.style.cssText = `
                  position: absolute;
                  top: -9999px;
                  left: -9999px;
                  white-space: nowrap;
                  padding-left:${style.paddingLeft};
                  padding-right:${style.paddingRight};
                  font-size: ${style.fontSize};
                  font-family: ${style.fontFamily};
                  font-weight: ${style.fontWeight};
                  letter-spacing: ${style.letterSpacing};
              `;
              tempElement.textContent = dom.textContent;
              document.body.appendChild(tempElement);
              const obj = {
                  status: tempElement.clientWidth + right + left > elementWidth,
                  width: elementWidth - left - right
              }
              document.body.removeChild(tempElement);
              return obj;
          }
          


          3. 創建一個block元素來包裹inline元素

          這種方法是在UI框架acro design vue中實現的。外層套一個塊級(block)元素,內部是一個行內(inline)元素。給外層元素設置溢出隱藏的樣式屬性,不對內層元素做處理,這樣內層元素的寬度是不變的。因此,通過獲取內層元素的寬度和外層元素的寬度作比較,就可以判斷出文本是否被溢出隱藏了。

          // html代碼
          <div class="title" id="test">
              <span class="content">近日,銀行紛紛下調大額存單利率,但銀行定期存款仍被瘋搶。銀行理財經理表示:有意向購買定期存款要盡快,不確定利率是否會再降。</span>
          </div>
          
          // 創建一個block元素來包裹inline元素
          const content = document.querySelector('.content');
          function getBlockDomWidth(dom) {
              const { left, right } = getPadding(dom);
              console.log(dom.clientWidth, content.clientWidth)
              const obj = { 
                  status: dom.clientWidth < content.clientWidth + left + right,
                  width: dom.clientWidth - left - right
              }
              return obj;
          }
          


          4. 使用canvas中的measureText方法和TextMetrics對象來獲取元素的寬度

          通過Canvas 2D渲染上下文(context)可以調用measureText方法,此方法會返回TextMetrics對象,該對象的width屬性值就是字符占據的寬度,由此也能獲取到文本的真實寬度,此方法有弊端,比如說兼容性,精確度等等。

          // 獲取文本長度
          function getTextWidth(text, font = 14) {
              const canvas = document.createElement("canvas");
              const context = canvas.getContext("2d")
              context.font = font
              const metrics = context.measureText(text);
              return metrics.width
          }
          


          2、JS獲取字符串長度的幾種常用方法

          1. 通過charCodeAt判斷字符編碼

          通過charCodeAt獲取指定位置字符的Unicode編碼,返回的值對應ASCII碼表對應的值,0-127包含了常用的英文、數字、符號等,這些都是占一個字節長度的字符,而大于127的為占兩個字節長度的字符。

          function calcTextLength(text) {
              let realLength = 0;
              for (let i = 0; i < text.length; i++) {
                  charCode = text.charCodeAt(i);
                  if (charCode >= 0 && charCode <= 128) {
                      realLength += 1;
                  } else {
                      realLength += 2;
                  }
              }
              return realLength;
          }
          


          2. 采取將雙字節字符替換成"aa"的做法,取長度

          function getTextWidth(text) {
              return text.replace(/[^\x00-\xff]/g,"aa").length;
          };
          



          作者:娜個小部呀
          鏈接:https://juejin.cn/post/7329967013923962895


          主站蜘蛛池模板: 成人精品一区二区激情| 末成年女AV片一区二区 | 国产一区二区三区在线电影| 伊人精品视频一区二区三区| 亚洲综合激情五月色一区| 国产一区二区三区在线视頻| 国产未成女一区二区三区| 麻豆亚洲av熟女国产一区二 | 国模吧一区二区三区| 全国精品一区二区在线观看| 成人免费一区二区三区在线观看| 日韩精品一区二区三区中文| 国产日韩一区二区三免费高清| 一区二区三区日本视频| 精品一区二区三区在线观看l| 久久亚洲中文字幕精品一区四 | 国产观看精品一区二区三区| 色噜噜一区二区三区| 国产无人区一区二区三区| 精品少妇人妻AV一区二区| 亚洲AV香蕉一区区二区三区| 中文字幕一区二区精品区| 亚洲蜜芽在线精品一区| 激情内射亚洲一区二区三区| 国产91精品一区二区麻豆网站 | 琪琪see色原网一区二区| 免费看无码自慰一区二区 | 人妻体内射精一区二区| 国产成人精品视频一区| 国产凸凹视频一区二区| 国产一区二区在线观看麻豆| 国产在线精品一区在线观看| 精品在线视频一区| 国产免费一区二区三区免费视频| 人妻内射一区二区在线视频| 国产av天堂一区二区三区| 国产成人精品一区二区秒拍| 日韩精品无码一区二区三区免费 | 3d动漫精品成人一区二区三| 亚洲一区欧洲一区| 国产一区在线电影|