表格變色示例中發現的問題——attr()與prop()

来源:https://www.cnblogs.com/planetwithpig/archive/2019/09/27/11597047.html
-Advertisement-
Play Games

在練習jQuery表格變色例子過程中,發現了一下幾個問題: 針對以上問題,查閱了資料後,發現了原因,以及解決方法: 在之前的jQuery版本中,都是使用attr()訪問對象的屬性,比如取一個圖片的alt屬性,就可以這樣做$('#img').attr('alt');但是在某些時候,比如訪問input的 ...


在練習jQuery表格變色例子過程中,發現了一下幾個問題:

  1. 在IEEdge瀏覽器中切換選中行會出現上一個表格行背景色被吃掉的情況;
  2. 在chrome中從上向下單擊行中任意單元可以選中該行,而從下往上單擊雖選中了行,而前面的按鈕列未顯示選中狀態

針對以上問題,查閱了資料後,發現了原因,以及解決方法:

  1. 為tbody設置border-collapse:collapse;方可解決吃色問題
  2. 在引用jQuery版本是1.6之後的,設置radio的checked屬性不應使用attr()方法,應使用prop()方法

 

在之前的jQuery版本中,都是使用attr()訪問對象的屬性,比如取一個圖片的alt屬性,就可以這樣做$('#img').attr('alt');但是在某些時候,比如訪問input的disabled屬性時,會有些問題,在有些瀏覽器中,只要寫了disable屬性就可以,有些則要寫:disabled="disabled"。所以,從1.6版本開始,jQuery使用新方法prop()獲取以及設置這些屬性,返回標準屬性:true/false。按照官方說明,如果設置disabled和checked這些屬性,應使用prop()方法(摘自《鋒利的jQuery(第2版)》)


附上我的代碼

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
 2 <html>
 3 <head>
 4     <title>表格變色</title>
 5     <style type="text/css">
 6         table{
 7             margin:auto;
 8             border:1px solid #ccc;
 9             padding:20px;
10             text-align:left;
11             /*添加上border-collapse屬性設置之後就可以解決在IEedge中選擇不同行之後吃色的問題*/
12             border-collapse:collapse;
13         }
14         tr{
15             padding:0px;
16             margin:0px;
17         }
18         td{
19             width:100px;
20             padding: 0px;            
21         }
22 
23         th{
24             border-bottom: 1px solid #ccc;
25         }
26         /*奇數行*/
27         .odd{
28             background: #ffffee;
29         }
30         /*偶數行*/
31         .even{
32             background: #fff38f;
33         }
34 
35         .selected{
36             background: gold;
37             color:#fff;
38         }
39     </style>
40     <script type="text/javascript" src="../jquery-3.4.1.js"></script>
41     <script type="text/javascript">
42         $(function(){
43             $("tbody>tr:odd").addClass("odd");//先排除第一行,然後給奇數行添加樣式
44             $("tbody>tr:even").addClass("even");//先排除第一行,然後給偶數行添加樣式
45 
46             $('tbody>tr').click(function(){
47                 $(this)
48                 .addClass('selected')
49                 .siblings().removeClass('selected')                    
50                 .end()
51                 // .find(':radio').attr("checked",true);//在設置input的checked屬性的時候,使用的是jq中的attr()方法;這個方法在jquery1.6以後的版本使用的時候會出現問題,應換成prop()方法。prop()方法通常用來設置元素固有的屬性,比如disabled和checked屬性。
52                 .find(':radio').prop("checked",true);                
53             });
54 
55             // 如果單選框預設情況下是選擇的,則高色.
56              // $('table :radio:checked').parent().parent().addClass('selected');
57             //簡化:
58               // $('table :radio:checked').parents("tr").addClass('selected');
59              //再簡化:
60              $('tbody>tr:has(:checked)').addClass('selected');
61 
62         })
63     </script>    
64 </head>
65 <body>
66     <table>
67         <thead>
68             <tr><th></th><th>姓名</th><th>性別</th><th>暫住地</th></tr>
69         </thead>
70         <tbody>
71             <tr><td><input type="radio" name="choice" checked='checked'></td><td>張三</td><td>男</td><td>北京</td></tr>
72             <tr><td><input type="radio" name="choice"></td><td>李四</td><td>男</td><td>上海</td></tr>
73             <tr><td><input type="radio" name="choice"></td><td>王五</td><td>女</td><td>北京</td></tr>
74             <tr><td><input type="radio" name="choice"></td><td>小明</td><td>男</td><td>上海</td></tr>
75             <tr><td><input type="radio" name="choice"></td><td>韓梅梅</td><td>女</td><td>北京</td></tr>
76             <tr><td><input type="radio" name="choice"></td><td>大牛</td><td>男</td><td>上海</td></tr>
77         </tbody>
78     </table>
79 </body>
80 </html>

每天進步一點點


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

-Advertisement-
Play Games
更多相關文章
  • 上一章節,我們介紹了Hexo的基礎搭建,搭建完大家一定發現,是英文版本的,並且頁面有點醜陋。這一章節,就來跟大家介紹Hexo的配置和主題的設置。 站點信息 上一章有跟大家提到過_config.yml這個文件,這個我們先稱之為站點全局的配置文件,後續我們說到主題的時候,也會有一個這樣的文件,暫時稱它主 ...
  • <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>簡易計算器</title> <script src="./lib/vue.js"></script> </head> <body> <div id="app">... ...
  • 1.安裝 less 和 less-loader。 命令: npm install less less-loader --save-dev 2.打開 build/webpack.base.conf.js ,在 module.exports = 的對象的 module.rules 後面 添加一段:{te ...
  • 在面試題中,閉包應該是必問的問題吧(以下內容純屬個人理解,歡迎大家指正不足) 下麵我們就簡單的瞭解一下閉包這個東西到底是什麼 首先,我們先來講講什麼是閉包 簡單來說就是一個定義在函數內部的函數,可以讀取到其他函數內部變數的函數,本質上,閉包就是一個把函數內部和外部連接起來的橋梁 那我們讀取函數內部的 ...
  • Hexo 是一個輕量級、簡潔、高效且高逼格的博客框架。Hexo 使用 Markdown(或其他渲染引擎)解析文章,在幾秒內,即可利用靚麗的主題生成靜態網頁。同時有著豐富的主題,官網或者GitHub都可以輕鬆下載到。由於Hexo博客都是靜態文件,所以推薦部署在Github上,不需要額外的伺服器和後臺, ...
  • 要知道這幾種寫法之間的區別,我們要先聊些題外話——js中函數的兩種命名方式,即表達式和聲明式。 函數的聲明式寫法為:function foo(){/*...*/},這種寫法會導致函數提升,所有function關鍵字都會被解釋器優先編譯,不管是聲明在什麼位置,都可以調用它,但是它本身不會被執行,定義只 ...
  • nodejs項目周 nodejs前端框架 一般做中間層 和操作資料庫 傳統模式和前後端分離最大的區別就是seo優化 HTTP常見的伺服器軟體 Apache Nginx (iis)微軟的伺服器現在已經不怎麼用了 node伺服器 可以自己編寫服務 個人練習 nodejs依賴安裝 Express框架 提供 ...
  • 版權申明: 本文原創首發於以下網站,您可以自由轉載,但必須加入完整的版權聲明 博客園MogooStudio: csdn博客MogooStudio: 最後效果 源碼分享 以下步驟詳細內容可能跟源碼中有出入,一切以源碼為準 CocosCreator版本:2.1.2,務必使用大於此版本的引擎運行 源碼地址 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...