搜索
系统检测到您的用户名不符合规范:

微信小程序图文混排不支持的解决方法

浏览:5006 发布日期:2017年09月21日 分类:功能实现 关键字: 微信小程序 小程序图文混排
微信小程序不支持动态生成页面,所以当我们将数据库的文章内容传到小程序页面的时候,传递的内容会原样显示,不进行解析。本文讲述如何解决微信小程序的图文混排问题。

微信小程序不支持动态生成页面,所以当我们将数据库的文章内容传到小程序页面的时候,传递的内容会原样显示,不进行解析,而是把html代码直接显示出来。本文讲述如何解决微信小程序的图文混排问题。
解决的思路是:
在服务端写接口的时候,从数据库中读取文章内容,将获取到的文章内容用正则表达式进行拆分,拆分成文章文字数组和图片数组。
然后将这两个数组返回给小程序。
小程序通过接口获取到文章数组和图片数组之后,分别进行遍历。
将内容数组遍历,并渲染到view标签中,同时根据数组的k值获取到图片对应的图片的路径,并将此地址渲染到image标签中。
服务端代码:
将ueditor上传的content内容中的图片信息提取出来:public function _filtercontent($content){
$content = preg_replace('/<\/?(html|head|meta|link|base|body|title|style|script|form|iframe|frame|frameset|p)[^><]*>/i','',$content);
$pattern ='<img.*?src="(.*?)">';
preg_match_all($pattern,$content,$matches);
return $matches[1];
}
此方法返回的是content中的所有图片的url组成的数组。
将ueditor上传的content内容中的文字信息提取出来:public function _setcontenttoarray($content){
$content = preg_replace('/<\/?(img)[^><]*>/i','#',$content);
$res = preg_replace('/<\/?(html|head|meta|link|base|body|title|style|script|form|iframe|frame|frameset|p|span|strong|sup)[^><]*>/i','',$content);
$res = str_replace(' ', "\r\t ", $res);
$res = str_replace('<br/><br/>', "\r\n", $res);
$res = str_replace('<br/>', "\r\n", $res);
$res = str_replace('<br>', "\r\n", $res);
$arr = explode('#', $res);
foreach( $arr as $k=>$v){
if( !$v )
unset( $arr[$k] );
}
return $arr;
}
此方法返回的是content中的文字切割成的数组
用上面的两个方法处理之后,文章内容已经被拆分成了两个部分,一个是图片数组,一个是文字数组。
然后是小程序端的处理:
<view class="and_image">
<block wx:for="{{infoData.article_content}}">
<text>{{item}}</text>
<image src="{{infoData['img_arr'][index]}}" mode="widthFix"></image>
</block>
</view>
原文链接http://www.zixuephp.cn/index.php/Home/Index/article/aid/178
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
哲涵
积分:1094 等级:LV3
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /