jquery實現的文本自定義換行效果

来源:http://www.cnblogs.com/come-on/archive/2016/01/31/5173184.html
-Advertisement-
Play Games

jquery實現的文本自定義換行效果:本章節介紹一下如何利用jquery實現文本的換行效果,當然這個換行效果比較粗糙,無法粉筆對應的位置是否該換行,不過希望能偶在代碼中學到一定的只是和開闊響應的思路。代碼如下: <!DOCTYPE html> <html> <head> <meta charset=


jquery實現的文本自定義換行效果:
本章節介紹一下如何利用jquery實現文本的換行效果,當然這個換行效果比較粗糙,無法粉筆對應的位置是否該換行,不過希望能偶在代碼中學到一定的只是和開闊響應的思路。
代碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
.content{
  width:20%;
  margin:auto;
  padding:15px;
  border:10px solid #6CF;
  text-align:left;
  line-height:20px;
  font-size:12px;
  font-family:Arial, Helvetica, sans-serif;
  position:relative;
  margin:0px;
}
.content label{
  display:inline-block;
  border:0;
  padding:0px;
  margin:0px;
}
</style>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.3.min.js"></script>
<script type="text/javascript"> 
var o=""; 
$(function(){ 
  o=$(".content").html(); 
  $("#bt").click(function(){
    change();
  })
}) 
function change(){ 
  var lw=0; 
  var maxs=0; 
  var line=$("#line").val(); 
  var h=o.split(""); 
  var webh="";
  for(var i=0;i<h.length;i++){ 
    webh+='<label>'+h[i]+'</label>'; 
  } 
  $(".content").html(webh); 
  $(".content label").each(function(){ 
    if(maxs>$(this).position()['left']){ 
      lw++; 
      maxs=0; 
      if(lw==line){ 
        $(this).before('<br/><br/>'); 
        lw = 0; 
      } 
    } 
    maxs = Math.max($(this).position()['left'],maxs); 
  }) 
} 
</script>
</head>
<body>
<center>
  <input id="line" type="text" value="1" />
  <input type="button" id="bt" value="改變" />
  <div class="content">螞蟻部落歡迎您,只有努力奮鬥才會有美好的明天,沒有人一開始就是高手,分享互助</div>
</center>
</body>
</html>

上面的代碼實現了我們的要求,文本框中是要進行換行的數字,如果是1,那麼字元串每一行後面都會加空行,如果是2,那麼沒兩行後面加空行,以此類推,下麵介紹一下它的實現過程。
一.代碼註釋:
1.var o="",聲明一個變數用來存儲獲取div下html內容。
2.$(function(){}),當文檔結構完全載入完畢再去執行函數中的代碼。
3.o=$(".content").html(),獲取div中的內容賦值給變數o。
4.$("#bt").click(function(){change();}),點擊按鈕執行事件處理函數,並調用change()函數。
5.function change(){},此函數實現了換行效果。
6.var lw=0,聲明一個變數並初始化為零,此變數用存儲分行的數目。[/s
7.var maxs=0,聲明一個變數用來存儲label標簽距離父元素的左邊距。
8.var line=$("#line").val(),獲取文本框值,也就是規定我們如何分行的數字。
9.var h=o.split(""),將字元串中的每一個字元進行分割。
10.var webh="",聲明一個變數用來存儲添加label標簽的內容。
11.for(var i=0;i<h.length;i++),遍曆數組中的每一個數組項,也就是每一個字元。
12.webh+='<label>'+h+'</label>',為原來字元串中的每一個字元外麵包裹label標簽。
13.$(".content").html(webh),將內容寫入div中。
14.$(".content label").each(function(){}),遍歷每一個label標簽。
15.if(maxs>$(this).position()['left']){},判斷的maxs的值是否大於當前label標簽距離父div元素的左邊距,如果不換行的話maxs的值不可能大於左邊距的,但是如果遇到父元素的邊緣出現換行就會大於左邊距了。
16.lw++,行數加1。
17.maxs=0,將maxs的值重置為0。
18.if(lw==line){$(this).before('<br/><br/>');lw = 0;} ,如果達到換行的數目,那麼就會添加換行標簽進行換行,並重置lw。
19.maxs = Math.max($(this).position()['left'],maxs),將maxs的值設置兩者較大的一個。
二.相關閱讀:
1.split()函數可以參閱javascript的split()函數使用介紹一章節。 [
2.html()函數可以參閱jQuery的html()方法一章節。
3.each()函數可以參閱jQuery的each()方法一章節。
4.position()函數可以參閱jQuery的position()方法一章節。
5.before()函數可以參閱jQuery的before()方法一章節。
6.Math.max()函數可以參閱JavaScript的Math.max()方法一章節。

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=13992

更多內容可以參閱:http://www.softwhy.com/jquery/


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

-Advertisement-
Play Games
更多相關文章
  • PHP,一門最近幾年興起的web設計腳本語言,由於它的強大和可伸縮性,近幾年來得到長足的發展,php相比傳統的asp網站,在速度上有絕對的優勢,想mssql轉6萬條數據php如需要40秒,asp不下2分鐘.但是,由於網站的數據越來越多,我們渴求能更快速的調用數據,不必要每次都從資料庫掉,我們可以從其
  • 在MacOs上配置hadoop和spark環境 Setting up Hadoop with Spark on MacOs Instructions 準備環境 如果沒有brew,先google怎樣安裝brew 先uninstall老版本的Hadoop brew cleanup hadoop 然後更新
  • jar包下載maven 配置: Xml代碼 收藏代碼 <dependency> <groupId>com.google.zxing</groupId> <artifactId>core</artifactId> <version>3.2.1</version> </dependency> Java代
  • 作業: 使用正則表達式和遞歸實現計算器功能。 實現: 1、實現帶括弧的計算 2、實現指數、加減乘除求餘等功能 一、實例說明: 本實例自己寫了個版本,但依舊存在一點bug,例:-2-2等計算問題,故最後在武SIR的代碼基礎上加了指數、求餘等功能。 該計算器思路: 1、遞歸尋找表達式中只含有 數字和運算
  • CSS3實現的滑鼠懸浮和移開div淡入淡出效果:本章節介紹一下如何利用css3實現滑鼠懸浮和離開div實現淡入淡出效果。代碼實例如下: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equi
  • jquery如何獲取當前元素的下一個元素:本章節介紹一下如何利用jquery獲取當前元素的下一個元素,如何利用原生js獲取下一個元素可以參閱原生js獲取當前元素的下一個元素代碼實例一章節, 下麵直接看代碼: <!DOCTYPE html> <html> <head> <meta charset="u
  • 更改select下拉菜單項獲取對應的值和文本:在實際應用中,更改select下拉菜單項就去執行一段代碼有著大量的應用,例如更改下拉菜單項實現頁面跳轉等,下麵介紹一下如何更改select下拉菜單項獲取當前選中的option項的value值和文本內容。代碼如下: <!DOCTYPE html> <htm
  • css實現的div垂直居中效果代碼實例:關於div垂直居中效果,在網上已經有很多介紹了。本章節再來通過代碼實例演示一下如何實現此效果,希望能夠給需要的朋友帶來幫助。代碼實例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...