html - 移动设备 HTML 表格样式

标签 html mobile html-table

如何更好地设计适合移动设备的表格?它在桌面上看起来不错,但当我尝试在手机上查看页面时,它显示的只是表格的中间,我必须左右滚动才能查看其他列。

这是网站 - https://sites.google.com/view/cash-counts-arbys/home

这是代码-

''' '''

<!DOCTYPE html>
<html>
<head>
  <style>
    body {
  background: #EEE;
  margin: 0;
  padding: 0;
}

/* Navigation */

.navigation {
  box-sizing: border-box;
  background-color: #3587A4;
  overflow: auto;
  padding: 18px 50px;
  position: relative;
  top: 0;
  width: 100%;
  z-index: 999;
}

ul {
  padding: 0;
  margin: 0;
}

li {
  color: #FFF;
  display: inline-block;
  font-family: 'Oxygen', sans-serif;
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 2px;
  margin: 0;
  padding: 20px 18px 10px 18px;
  text-transform: uppercase;
}

.active {
  color: #88CCF1;
}

/* Table */

table {
  height: 40%;
  left: 10%;
  margin: 20px auto;
  overflow-y: scroll;
  position: static;
  width: 80%;
}

thead th {
  background: #88CCF1;
  color: #FFF;
  font-family: 'Lato', sans-serif;
  font-size: 16px;
  font-weight: 100;
  letter-spacing: 2px;
  text-transform: uppercase;
}

tr {
  background: #f4f7f8;
  border-bottom: 1px solid #FFF;
  margin-bottom: 5px;
}

th, td {
  font-family: 'Lato', sans-serif;
  font-weight: 400;
  padding: 20px;
  text-align: left;
  width: 33.3333%;
}

.search {
  background-color: #FFF;
  border: 1px solid #DDD;
  border-radius: 3px;
  color: #AAA;
  padding: 20px;
  margin: 50px auto 0px auto;
  width: 77%;
}
  </style>
  <title>Arbys Draw Counts</title>
  <link href="https://fonts.googleapis.com/css?family=Lato: 100,300,400,700|Luckiest+Guy|Oxygen:300,400" rel="stylesheet">
  <link href="style.css" type="text/css" rel="stylesheet">
</head>
<body>

  <ul class="navigation">
    <li><img src="" height="80px;"></li>
    <li>Arby's Draw Counts</li>
    <li>Made by _</li>
  </ul>
  <table>
  <tr>
    <th>Bill Type</th>
    <th>Amount of Bills</th>
    <th>Cash Amount of Type</th>
  </tr>
  <tr>
    <td><label for="usd-100">100$</label></td>
    <td><input id="usd-100" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-100">0</output>$</td>
  </tr>
  <tr>
    <td><label for="usd-50">50$</label></td>
    <td><input id="usd-50" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-50">0</output>$</td>
  </tr>
  <tr>
    <td><label for="usd-20">20$</label></td>
    <td><input id="usd-20" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-20">0</output>$</td>
  </tr>
  <tr>
    <td><label for="usd-10">10$</label></td>
    <td><input id="usd-10" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-10">0</output>$</td>
  </tr>
  <tr>
    <td><label for="usd-5">5$</label></td>
    <td><input id="usd-5" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-5">0</output>$</td>
  </tr>
  <!DOCTYPE html>
  <html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
  </head>
  <body>
  
  </body>
  </html>
  <tr>
    <td><label for="usd-1">1$</label></td>
    <td><input id="usd-1" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-1">0</output>$</td>
  </tr>
  <tr>
    <td colspan="2">Sum</td>
    <td><output for="usd-100 usd-50 usd-20 usd-10 usd-5 usd-1" id="sum-total">0</output>$</td>
  </tr>
</table>
<table>
  <tr>
    <th>Change Type</th>
    <th>Number of Coins</th>
    <th>Cash Amount of Type</th>
  </tr>
  <tr>
    <td><label for="usd-quarter">0.25$</label></td>
    <td><input id="usd-quarter" type="number" step="1" min="0" value="0"></td>
    <td><output for="usd-quarter">0</output>$</td>
  </tr>
  <tr>
    <td><label for="usd-dime">0.10$</label></td>
    <td><input id="usd-dime" type="number" step="1" min="0" value="0"></td>
    <td><output for="usd-dime">0</output>$</td>
  </tr>
  <tr>
    <td><label for="usd-nickel">0.05$</label></td>
    <td><input id="usd-nickel" type="number" step="1" min="0" value="0"></td>
    <td><output for="usd-nickel">0</output>$</td>
  </tr>
  <!DOCTYPE html>
  <html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
  </head>
  <body>
  
  </body>
  </html>
  
  <tr>
    <td><label for="usd-penny">0.01$</label></td>
    <td><input id="usd-penny" type="number" step="1" min="0" value="0">$</td>
    <td><output for="usd-penny">0</output>$</td>
  </tr>
  <tr>
    <td colspan="2">Sum</td>
    <td><output for="usd-quarter usd-dime usd-nickel usd-penny" id="sum-total-change">0</output>$</td>
  </tr>
</table>
</body>
</html>

<html>
<body>
  <table>
    <tr>
      <th>Sum of Draw</th>
      <th>Drop</th>
      <th>Draw After Drop</th>
    </tr>
<!DOCTYPE html>
  <html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
  </head>
  <body>
  
  </body>
  </html>
  
    <tr>
      <td><output id="draw">0</output>$</td>
      <td><input id="drop" type="number" step="1" min="0" value="0">$</td>
      <td><output id="newdraw">0</output>$</td>
    </tr>
  </table>
</body>
</html>
<script>
document.querySelectorAll('input').forEach(el =>
  el.addEventListener('change', function() {
    // getting the value of the inputs
    let usd_100     = +document.querySelector('#usd-100').value,
        usd_50      = +document.querySelector('#usd-50').value,
        usd_20      = +document.querySelector('#usd-20').value,
        usd_10      = +document.querySelector('#usd-10').value,
        usd_5       = +document.querySelector('#usd-5').value,
        usd_1       = +document.querySelector('#usd-1').value,
        usd_quarter = +document.querySelector('#usd-quarter').value,
        usd_dime    = +document.querySelector('#usd-dime').value,
        usd_nickel  = +document.querySelector('#usd-nickel').value,
        usd_penny   = +document.querySelector('#usd-penny').value,
        drop        = +document.querySelector('#drop').value;
    
    // calculating the sum of each row
    let sum_usd_100     = usd_100 * 100,
        sum_usd_50      = usd_50 * 50,
        sum_usd_20      = usd_20 * 20,
        sum_usd_10      = usd_10 * 10,
        sum_usd_5       = usd_5 * 5,
        sum_usd_1       = usd_1 * 1,
        sum_usd_quarter = usd_quarter / 4,
        sum_usd_dime    = usd_dime / 10,
        sum_usd_nickel  = usd_nickel / 20,
        sum_usd_penny   = usd_penny / 100,
        sum_drop        = drop * 1;
    
    // outputting the sum of each row
    document.querySelector('output[for="usd-100"]').value = sum_usd_100;
    document.querySelector('output[for="usd-50"]').value = sum_usd_50;
    document.querySelector('output[for="usd-20"]').value = sum_usd_20;
    document.querySelector('output[for="usd-10"]').value = sum_usd_10;
    document.querySelector('output[for="usd-5"]').value = sum_usd_5;
    document.querySelector('output[for="usd-1"]').value = sum_usd_1;
    document.querySelector('output[for="usd-quarter"]').value = sum_usd_quarter;
    document.querySelector('output[for="usd-dime"]').value = sum_usd_dime;
    document.querySelector('output[for="usd-nickel"]').value = sum_usd_nickel;
    document.querySelector('output[for="usd-penny"]').value = sum_usd_penny;
    
    // getting the total sum of the entire column
    document.querySelector('#sum-total').value = sum_usd_100 + sum_usd_50 + sum_usd_20 + sum_usd_10 + sum_usd_5 + sum_usd_1;
    document.querySelector('#sum-total-change').value = sum_usd_quarter + sum_usd_dime + sum_usd_nickel + sum_usd_penny;
    document.querySelector('#draw').value = sum_usd_100 + sum_usd_50 + sum_usd_20 + sum_usd_10 + sum_usd_5 + sum_usd_1 + sum_usd_quarter + sum_usd_dime + sum_usd_nickel + sum_usd_penny;
    document.querySelector('#newdraw').value = sum_usd_100 + sum_usd_50 + sum_usd_20 + sum_usd_10 + sum_usd_5 + sum_usd_1 + sum_usd_quarter + sum_usd_dime + sum_usd_nickel + sum_usd_penny - sum_drop;
  })
)
</script>

''' '''

最佳答案

由于一些原因,表格本质上响应速度不太快,这也是它们不再经常使用的众多原因之一。您最好使用 display: grid 系统。

表格不响应的原因是,一旦将内容输入到单元格中,它就会卡在该单元格、该列、该行中,直到时间结束,除非您想让样式变得非常复杂。

现在,你的 table 上有自己的卷轴,它已经对你起作用了。在小视口(viewport)中,该滚动将使您在触摸屏上滚动变得更加困难。事实上,大多数交互在触摸屏上都比较困难,这就是为什么移动优先设计在首次构思十多年后至今仍在使用。首先针对具有更多要求和更少功能的屏幕进行设计比尝试适应已经完成的大屏幕设计更容易。

我有一些建议可以帮助您开始:

  1. 去掉 table 上的内卷
  2. 使用 display: grid; 而不是表格
  3. 首先为移动设备设计基于网格的新表单,然后针对桌面设备调整移动设备
  4. 使用手机查看具有类似内容的页面,了解边距、内边距、高度、字体大小等的大小。

关于html - 移动设备 HTML 表格样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74255932/

相关文章:

html - 固定 HTML 表格中的特定行或列

android - Eclipse IDE 无法识别 LG G2 (android 4.4.2 kitkat)

java - 发送图片到服务器

javascript - 用于将 HTML 转换为 Markdown 的 Jquery 插件

html - 列 flex 重叠后的 IE 11 元素

android - 如何保持flutter应用程序在后台运行(防止被杀死)

JavaScript 或 jQuery 加粗表格的最后一行并删除超链接。 ID 为 "My_Table_1"的表

php - PDO插入语句未执行

html - 在 CSS 中用 1 个 div 重叠圆圈

html - 如何根据文本将图像居中对齐