后盾网ThinkPHP学习笔记——数据库导入与模板输出使用、ajaxReturn与F函数ThinkPHP教程

/ / 2016-10-09   阅读:2493
        在配置项配置'DEFAULT_FILTER' => 'htmlspecialchars',,这样post等获取到的数据就会采取htmlspecialchars进行过滤。就不用'username' => I('username','','htmlspecialchars'),...
        在配置项配置'DEFAULT_FILTER' => 'htmlspecialchars',,这样post等获取到的数据就会采取htmlspecialchars进行过滤。就不用'username' => I('username','','htmlspecialchars'),了,直接写成'username' => I('username'),即可。
        ajaxReturn方法用于AJAX调用后返回数据给客户端,支持JSON、XML和EVAL三种方式给客户端接受数据。
        这里,ThinkPHP导入数据到数据库中,只需数据的数组的项名称与数据库的项名称一样,'username' => I('username'),这样就可以用M('wish')->data($data)->add()将数据$data导入到数据表‘[表前缀]wish’中了。
        而数据库中的数据输出到模板中也很简单,index函数中$this->wish=M('wish') -> select();$this->display();,这两句的第一句是将数据表‘[表前缀]wish’的数据取出将放入到一个名字为wish的数组中,后一句是指此函数的显示模板是index.html。index.html即可用ThinkPHP自带的标签foreach将wish数组里面的数据循环显示出来了,如下:
<foreachname='wish'item='v'><dlclass='paper a<{:mt_rand(1,5)}>'><dt><spanclass='username'><{$v.username}></span><spanclass='num'>No.<{$v.id}></span></dt><ddclass='content'><pre><{$v.content|replace_phiz=###}></pre></dd><ddclass='bottom'><spanclass='time'><{$v.time|date='Y-m-dH:i',###}></span><ahref=""class='close'></a></dd></dl></foreach>
        这里后盾教程一点击“我要起愿”时,触发$( '#send' ).click函数,弹出填写起愿框。填写后起愿框后,点击“发布”,触发$('#send-btn').click,这个js函数里面用jQuery.post将起愿框接收到的数据传给handleURL,handleURL即是后台的handle函数,后台handle函数判断数据是ajax方式传入后,即录入数据中,并将数据重新处理,替换表情等,返回给jQuery.post,让提交的数据不用刷新,即显示出在起愿墙中。
        后台函数是这样的:
publicfunctionhandle(){if(!IS_AJAX)  halt('页面不存在');  //_404('页面不存在',U('Index'));$data = array(
    'username' => I('username'),
    'content' => I('content'),
    'time' => time()
    );

        if($id = M('wish')->data($data)->add()){
            $data['id'] = $id;
            $data['content'] = replace_phiz($data['content']);
            $data['time'] = date('Y-m-d H:i',$data['time']);
            $data['status'] = 1;
            $this ->ajaxReturn($data, 'json');
        }else{
            $this ->ajaxReturn(array('status' => 0), 'json');
        }
        而js的jQuery.post是这样写的。
$.post(handleURL, {username : username.val(), content : content.val()},
function (data) {
$('#close').click();
if(data.status) {
var str = '<dlclass="paper a1">';
str += '<dt><spanclass="username">' + data.username + '</span>';
str += '<spanclass="num">' + data.id + '</span>';
str += '</dt><ddclass="content"><pre>' + data.content +'</pre></dd>';
str += '<ddclass="bottom"><spanclass="time">' + data.time + '</span>';
str += '<ahref=""class="close"></a></dd></dl>';
$('#main').append(str);
$('#close').click();

}else{
alert('发布失败');
}
},'json');
        这视频还用到F函数,是为了保存处理表情的一个数组:
$phiz = array(
            'zhuakuang' => '抓狂',
            'baobao' => '抱抱',
            'haixiu' => '害羞',
            'ku' => '酷',
            'xixi' => '嘻嘻',
            'taikaixin' => '太开心',
            'touxiao' => '偷笑',
            'qian' => '钱',
            'huaxin' => '花心',
            'jiyan' => '挤眼'
            );
        F('phiz',$phiz,'./Data/');

我要评论

昵称:
验证码:

最新评论

共0条 共0页 10条/页 首页 上一页 下一页 尾页
意见反馈