HTML表单tr、th、tb的区别

tr表示table中的行;th表示table中的表的头部,例如一篇文章的标题;tb表示table中的列

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"><head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>欢迎来到我的御书房</title> <style> .style1{ font-family: "Times New Roman", Times, serif; font-size: 16px; line-height: 1.6; color: #333; } a { text-decoration: none; } table { width: 1000px; border-collapse: collapse; background: linear-gradient(to right, #e0eafc, #cfdef3); } th, td { border: 1px solid #ddd; padding: 8px; text-align: left; border: 1px solid #ddd; padding: 5px; } th { background-color: #f2f2f2; text-align: center; } th:hover { color: #0056b3; /* 鼠标悬停时颜色稍变深 */ } tr:nth-child(odd) { background-color: #f2f2f2; } </style> </head> <?php include("conn.php"); ?> <body> <div id="apDiv1" align="center"><img src="lili3277.jpg" width="796" height="108" /></div> <div id="apDiv2"> <table width="867" border="0" align="center" > <tr> <th width="105"><span class="style1"><?PHP echo date("Y-m-d"); ?></span></th> <th width="114"><span class="style1"><a href="index.php">首页</a></span></th> <th width="125"><span class="style1"><a href="borrow.php">浏览信息</a></span></th> <th width="116"><span class="style1"><a href="add.php">添加图书</a></span></th> <th width="102"><span class="style1"><a href="search.php">简单查询</a></span></th> <th width="93"><span class="style1"><a href="searchmore.php">复杂查询</a></span></th> <th width="90"><span class="style1"><a href="group.php">分组统计</a></span></th> <th width="88"><span class="style1"><a href="quit.php">退出系统</a></span></th> </tr> </table> </div> <div id="apDiv3"> <form id="forml" name="forml" action="" method="post"> <table width="778" border="1" align="center"> <tr> <th width="97"><a href=" ?od=id" class="style1">图书编号</a></th> <th width="93"><a href=" ?od=bookname" class="style1">图书名称</a></th> <th width="95"><a href=" ?od=issuDate" class="style1">出版日期</a></th> <th width="93"><a href=" ?od=price" class="style1">图书定价</a></th> <th width="57"><a href=" ?od=maker" class="style1">作者</a></th> <th width="76"><a href=" ?od=publisher" class="style1">出版社</a></th> <th width="92"><span class="style1">操作</span></th> </tr> <?php $od=$_GET[od]; if($od==""){ $sql="select * from tb_book order by id desc limit 12";}else{ $sql="select * from tb_book order by ".$od." desc limit 12"; } $result=mysqli_query($conn,$sql); while($myrow=mysqli_fetch_array($result)){ ?> <tr> <td><div align="center"><span class="style1"><?php echo $myrow[0]; ?></span></div></td> <td><div align="center"><span class="style1"><?php echo $myrow[1]; ?></span></div></td> <td><div align="center"><span class="style1"><?php echo $myrow[2]; ?></span></div></td> <td><div align="center"><span class="style1"><?php echo $myrow[3]; ?></span></div></td> <td><div align="center"><span class="style1"><?php echo $myrow[4]; ?></span></div></td> <td><div align="center"><span class="style1"><?php echo $myrow[5]; ?></span></div></td> <td><div align="center"><span class="style1"><a href="del.php?id=<? echo $myrow[0]?>">删除</a>/<a href="update.php?id=<? echo $myrow[0]?>">修改</a></span></div></td> </tr> <?php }?> </table> </form> </div> <div id="apDiv4"> <p align="center">版权所有:22电子商务专业</p> <p align="center">校址:安徽省池州市教育园区</p> </div> </body> </html> 这个代码显示出的图书名称等信息是乱码,帮我分析一下什么问题, <?php $conn = mysqli_connect("localhost", "root", "root", "db_database18") or die("连接数据库服务器失败!".mysqli_connect_error()); mysqli_query($conn,"set name utf8"); ?> 上面这个是数据库连接文件,图书信息在数据库里可以正常显示
最新发布
06-07
<think>嗯,用户遇到了PHP页面从MySQL读取数据时出现乱码的问题,特别是图书名称等中文字符显示异常。用户明确提到了使用utf8编码和mysqli_set_charset函数,说明已经有基础概念但配置可能不完整。从引用内容看,用户提供了几个关键线索:1)引用[1][2]显示character_set_client等变量实际是latin1而不是utf82)引用[2]提到mysqli_set_charset对比SETNAMES的优劣3)引用[4]展示了表单accept-charset的设置用户的核心痛点是:明明设置了utf8却仍有乱码。这通常发生在字符集不匹配的"传输环节"。需要特别注意PHP5.3以上版本中,mysqli_set_charset比SETNAMES更优,因为它会修正mysqlnd驱动的内部字符指针。解决方案应该覆盖四个层面:1)数据库存储层(建表语句)2)连接传输层(mysqli_set_charset)3)PHP输出层(header/content-type)4)HTML元信息层(metacharset)特别要强调用户容易忽略的细节:-必须使用$mysqli->set_charset()而非query执行SETNAMES-浏览器检查时会发现实际响应头是text/html-表单提交需要与页面编码一致最后准备的问题要引导用户检查具体哪个环节断裂了,比如通过打印字符集变量、检查http响应头、表单编码验证等。乱码问题往往需要逐环节排查,所以问题设计成诊断链条比较合适。</think> 要解决PHP页面显示MySQL数据乱码的问题,需确保**全链路编码一致使用UTF-8**。以下是具体解决方案: --- ### 解决方案步骤: 1. **数据库表结构设置** 确保建表语句指定字符集: ```sql CREATE TABLE books ( id INT PRIMARY KEY AUTO_INCREMENT, title VARCHAR(255) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; ``` 2. **PHP连接层设置字符集** 在数据库连接后**立即**设置: ```php $mysqli = new mysqli("localhost", "user", "password", "database"); // 关键!使用set_charset()而非SET NAMES $mysqli->set_charset("utf8mb4"); // 优先用utf8mb4支持emoji ``` 3. **PHP输出层设置HTTP头** 在页面顶部添加: ```php header('Content-Type: text/html; charset=utf-8'); ``` 4. **HTML元标签声明** 在`<head>`内添加: ```html <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> ``` 5. **表单提交设置(若涉及)** 如引用[4]所述: ```html <form accept-charset="UTF-8" method="post"> <!-- 表单内容 --> </form> ``` --- ### 重点排查点: 1. **验证MySQL当前字符集** ```sql SHOW VARIABLES LIKE 'character_set_%'; ``` 需确认: - `character_set_client` - `character_set_connection` - `character_set_results` 全部为 **`utf8mb4`** 2. **确认mb4支持** 执行 `SELECT "中文字符"`,若正常显示则数据库存储层无误[^1]。 3. **浏览器编码强制检查** 右键页面 → 编码 → 确认选择 UTF-8 --- ### 常见错误: ❌ `SET NAMES 'utf8'` 👉 应改用 `$mysqli->set_charset("utf8mb4")`,因其同步修正PHP内部字符处理[^2]。 ❌ `CREATE TABLE ... CHARSET=utf8` 👉 MySQL的`utf8`实际为三字节编码(不完整),**必须用`utf8mb4`**[^1]。 --- ### 完整代码示例 ```php <?php // 1. 设置HTTP头 header('Content-Type: text/html; charset=utf-8'); // 2. 连接数据库+字符集 $mysqli = new mysqli("127.0.0.1", "user", "pass", "db_name"); if ($mysqli->connect_error) die("连接失败"); $mysqli->set_charset("utf8mb4"); // 关键语句 // 3. 查询数据 $result = $mysqli->query("SELECT title FROM books"); while ($row = $result->fetch_assoc()) { echo "书名:" . $row['title'] . "<br>"; // 正常显示中文 } ?> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- 双重保障 --> </head> <body> <!-- 内容 --> </body> </html> ``` --- **原因总结**:乱码通常由**连接传输层字符集不匹配**导致[^2],按以上四层配置可彻底解决。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值