php 二维数组传递给 js 问题解决记录
php 二维数组传递给 js 问题解决记录
需求:
php从数据库中读取到二维数组,传递到js中
实现步骤:
php:json_encode → json → js:eval
即在php中使用json_encode()将php的二维数组转化成json格式,传递到js中,使用eval()解析得到js的二维数组。
代码:
php:
<?php header("Content-Type: text/html; charset=utf8") ; $con=mysqli_connect("url","name","password","databasename"); // Check connection if (mysqli_connect_errno($con)) echo "Failed to connect to MySQL: " . mysqli_connect_error(); mysqli_query($con,"set character set 'utf8'"); mysqli_query($con,"set names 'utf8'"); $json_arr = array(array("a","b","c",1,2,3),array("q","w",1,2)); $jsonstr = json_encode($json_arr); ?> var json=<?=$jsonstr?>;
<script type="text/javascript" src="http://.../test.php"></script> <script language="javascript" type="text/javascript"> $(document).ready(function(){ var jsonstr =eval(json); for(var k=0;k<jsonstr.length;k++){ for(var i=0;i<jsonstr[k].length;i++) alert(jsonstr[k][i]); } }) </script>
遇到的问题:
1.php中二维数组使用json_encode()转化成json时,第二维数组可以echo出来,但是转化成json为空。
到网上查资料确定问题是第二维数组中含有非utf8编码。果然,我把二维数组中第二维数组互换位置,变成第一个数组的json为空了。
结论:json_encode()可以转化多维数组,但是基本要求是编码为utf8。遇到多维数组中某一子数组转化json为null,极有可能使这一子数组中含有编码不是utf8的元素。
2.wamp mysql 在phpmyadmin中看到数据表内容是正常汉字,但是用php读取出来打印发现汉字都变成?了。
数据库中各个表的整理方式都是utf8_general_ci,php文件中也声明了
header("Content-Type: text/html; charset=utf-8") ; ... mysqli_query($con,"set character set 'utf-8'"); mysqli_query($con,"set names 'utf-8'");
应该是这样:
header("Content-Type: text/html; charset=utf8") ; ... mysqli_query($con,"set character set 'utf8'"); mysqli_query($con,"set names 'utf8'");

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

使用foreach循环去除PHP数组中重复元素的方法如下:遍历数组,若元素已存在且当前位置不是第一个出现的位置,则删除它。举例而言,若数据库查询结果存在重复记录,可使用此方法去除,得到不含重复记录的结果。

PHP数组键值翻转方法性能对比表明:array_flip()函数在大型数组(超过100万个元素)下比for循环性能更优,耗时更短。手动翻转键值的for循环方法耗时相对较长。

PHP中深度复制数组的方法包括:使用json_decode和json_encode进行JSON编码和解码。使用array_map和clone进行深度复制键和值的副本。使用serialize和unserialize进行序列化和反序列化。

多维数组排序可分为单列排序和嵌套排序。单列排序可使用array_multisort()函数按列排序;嵌套排序需要递归函数遍历数组并排序。实战案例包括按产品名称排序和按销售量和价格复合排序。

在PHP中执行数组深度复制的最佳实践是:使用json_decode(json_encode($arr))将数组转换为JSON字符串,然后再将其转换回数组。使用unserialize(serialize($arr))将数组序列化为字符串,然后将其反序列化为新数组。使用RecursiveIteratorIterator迭代器对多维数组进行递归遍历。

PHP的array_group_by函数可根据键或闭包函数对数组中的元素分组,返回一个关联数组,其中键是组名,值是属于该组的元素数组。

PHP数组合并去重算法提供了并行的解决方案,将原始数组分成小块并行处理,主进程合并块的结果去重。算法步骤:分割原始数组为均等分配的小块。并行处理每个块去重。合并块结果并再次去重。

PHP的array_group()函数可用于按指定键对数组进行分组,以查找重复元素。该函数通过以下步骤工作:使用key_callback指定分组键。可选地使用value_callback确定分组值。对分组元素进行计数并识别重复项。因此,array_group()函数对于查找和处理重复元素非常有用。
