截断字符

最近作一个应用,是经过客户端和网页交互来实现替换文档中字体的功能;在网页方面的工做很简单,就是经过客户端提供的接口获取当前系统字体,显示在界面供用户选择替换。是的,页面很顺利作完,并在浏览器测试完毕。开始和客户端作一个完整测试,结果问题来了,ie8显示不了英文字体选项,ie6显示不了背景图片。由于最终是生成dll,因此不能用浏览器来调试,很不方便,调试的过程只能在页面显示出来,没办法,只能逐步排除。css

针对第一个问题:数组

首先,检测客户端接口是否有返回字体,正确;在明确知道有获取到字体后,检测对字体处理是否正确,也是正确。最后检测拼接标签,生成文档节点是否正常,这是否发现问题,拼接的结果出错,一个长度为N的数组,结果只显示循环的第一个,并且后面是被截断了,有点疑惑,我已经作过特殊字符处理的,并且为何显示的是一个截断的拼接结果。浏览器

从新检查,把接口返回的结果拿到页面上直接测试,结果显示是正常的,这下有点蒙了,字符串没有问题,拼接方法也没有问题,但为何在客户端的结果有问题?百思不得其解,最后灵光一闪,用编码后的数据来拼接试试,编码后出现%00,正常显示拼接结果,发现问题所在,天然就容易解决了;%00,截断,作下过滤就能够了,解决。测试

针对第二个问题:字体

一开始怀疑是客户端里面不支持png,可是后面因为在调试第一个问题的时候,使用一个在线网页在调试(这个应用实际只是客户端和本地页面,是用一个在线的网页,只是为了调试的时候,不用每改一次都去生成一个新的dll);发现IE6下是正常显示png的,因此排除图片格式问题;猜想是图片路径引用的问题,使用先对路径引用是合法并在浏览器正常工做,在客户端,总有些奇奇怪怪的问题,因此才有这种猜想,恰好另一个正常显示图片的页面,css是直接写在页面上的,图片也是用相对地址引用,难道是不能在引入的css文件里面使用背景图片。没头绪,直接放在页面上测试,结果仍是现实不了,我了个去,这太不科学了。对比了下正常显示背景图片的写法,没有什么区别啊.就是在地址后面对了参数而已.例子:../img/dsjiofafd.png?v=版本,这个正常不过的写法了,不可能这里出错。可是仍是想不出因此然,只能去掉试试,结果发现,偏偏是假多了后面‘?v=版本’致使不能显示。完全无语了....编码

 

最后,记录下这郁闷的事情调试

相关文章
相关标签/搜索