A4纸网页打印——宽高设置
作者:admin 日期:2019-12-21
一、在公制长度单位与屏幕分辨率进行换算时,必须用到一个DPI(Dot Per Inch)指标。 经过我仔细的测试,发现了网页打印中,默认采用的是96dpi,并非传闻的72dpi 。
A4纸张的尺寸是210×297mm,按1英寸=25.41mm换算,即8.264×11.688英寸 。所以,A4纸96dpi下的分辨率是794×1123,这就是我们在制作网页的时候需要的象素。
但是打印机是无法满幅打印的,总要有页边距,所以我们在制作网页的时候必须减去页边距。
以下是我测试的各种页边距下,A4纸对应的象素尺寸:
-
打印页边距设定为 0mm 时,网页内最大元素的分辨率:794×1123
php ajax提交post请求出现数组被截断情况的解决方法
作者:admin 日期:2019-12-14
一、场景
今天做保存专题商品列表的时候发现,前端明明有2300多条数据,但是实际服务端接受存入数据库才166条
二、解决过程
经过调试发现前端页面提交post请求时数据量是正确的,但到服务端只能接受到166条。
一开始以为是post请求长度超过限制,不过看了下请求内容才200多K,而post请求默认支持8M以内的数据传输。
于是怀疑可能是php内部配置导致的,后来百度了下果不其然发现max_input_vars这个配置项,该配置项是在php 5.3.9版本之后才加入的,目的是为了防止hash冲突。
既然如此那就改下该配置项,默认是1000,改成10000;重启服务后发现服务端获取到的数据量是1666,是之前的10倍,正好也是配置项调整之后的倍数。
然而前端传的数据量是不确定的,就算把max_input_vars设置成10万,也有可能不够用,还是另寻他法吧。
三、最终解决方法
1、前端将数组转换成json传输,即JSON.stringify(goodsList)
2、服务端接收到并解析$goodsList = json_decode($_POST['goodsList'], true);
3、测试发现前端传过来的数据服务端都能获取到,问题圆满解决
解决PHP使用POST提交数据不完整,数据不全的问题
php利用array_search与array_column实现二维数组查找
作者:admin 日期:2019-12-13
利用array_search与array_column实现二维数组查找,不用自己写个循环,减少工作量。
- <?php
- $userdb = array(
- 0 => array(
- 'uid' => 100,
- 'name' => 'Sandra Shush',
- 'url' => 'urlof100'
- ),
- 1 => array(
- 'uid' => 5465,
- 'name' => 'Stefanie Mcmohn',
- 'pic_square' => 'urlof100'
- ),
- 2 => Array(
- 'uid' => 40489,
- 'name' => 'Michael',
- 'pic_square' => 'urlof40489'
- )
- );
- $found_key = array_search(40489, array_column($userdb, 'uid'));
- /**
- 如果$userdb很大,建议使用一个变量,避免搜索每个元素时都调用array_column()
- $uid = array_column($userdb, 'uid');
- $found_key = array_search(40489, $uid);
- */
- var_dump($found_key);
- ?>
array_search() 函数在数组中搜索某个键值,并返回对应的键名。
php限制几点到几点
作者:admin 日期:2019-12-12
public function get_curr_time_section()
广告位