解析 thinkphp 框架中的部分方法


Posted in PHP onMay 07, 2017

 1 thinkphp 框架 中判断输入的数值和数据库中的数值是否一致

   首先 需要在view文件夹下建一个模板 名为zhuce.html

<html>
<head>
  <script src="__ROOT__/Public/js/jquery-1.11.2.min.js"></script>
</head>
<body>
    <div> 账号:<input type="text" name="num" id="uid"></div>
    <div id="ts"></div>
</body>
</html>

我在控制器TextController.class.php中写了一个方法zhuce(),显示模板

function zhuce()
{
  $this->show();
}

这里需要用到ajax来写的,首选需要引入jquery包 已经在上面引入了

<script type="text/javascript">
  $("#uid").blur(function(){
  var num = $(this).val();
  $.ajax({
    url:"__CONTROLLER__/chuli",
    data:{num:num},
    type:"POST",
    dataType:"TEXT",
    success:function(data)
     {
        if(data.trim()=="1")
         {
           $("#ts").html("此账号已经存在");
          } 
       else  
        {
             $("#ts").html("此账号可用"); 
         }
      }
})
})

</script>

上面涉及到一个chuli方法,那么这儿我们要开始写chuli方法了

function chuli()
{
   $n=D("login");
   $num=$_POST["num"];
   $aa=$n->where("num='{$num}'")->count();
    $this->ajaxReturn($aa,"eval");
}

这样就可以来判断这个账号是不是可以使用了,但是我们会发现有一个小bug,就是如果是空的话,那么会显示此账号可以使用,为了避免出现这样的失误,我们可以在js中 判断一下是不是为空  if(num.trim()==""){$("#ts").html("账号不可以为空")} else{执行ajax部分的内容就可以了}

2 验证方法:

 首先是判断不为空的方法,这里可以直接用js来写是非常简单的,用的是nation表  我在view文件夹下写了一个jsdongtai.html的文件,

<html>
<head>
  <script src="__ROOT__/Public/js/jquery-1.11.2.min.js"></script>
</head>
<body>
  <div>
    代号:<input type="text" id="code"/>
    <span id="ts"></span>
  </div>
</body>
</html>

然后就是判断代号是否为空

<script type="text/javascript">
  $("#code").blur(function(){
   var code=$(this).val();
   if(code.trim()=="")
   {
     $("#ts).html("代号不能为空");
   }
   else
  {
    $("#ts").html("验证通过");
  }

})

</script>

然后用jsdongtai方法调一下就可以了 function jsdongtai(){$this->show();}

如果我们用ajax来调的话可能比较麻烦,但是对于其他的验证来说要方便的多了,我们可以在方法里面添加多个验证

比如我们用一个dongtai.html的模板  和jsdongtai.html的html部分是一样的,这样我们就只需要写ajax部分就可以了  

<script type="text/javascript">
 $("#code").blur(function(){
   var code=$(this).val();
   $.ajax({
     url:"__CONTROLLER__/yanzheng",
     data:{code:code},//第一个code必须是和表中的一致
    type:"POST",
    dataType:"TEXT",
     success:function(data)
      {
        if(data.trim()=="1")
          {
            $("#ts").html("验证通过"),
          }
          else
          {
            $("#ts").html("此处不能为空"),
          }
      }
})
})
</script>

 下面是yanzheng方法

function yanzheng()
{
   $n=D("nation");
   $a=array(
    array("code","require","此处不能为空"))
    if($n->validate($a)->create())
     {
        $this->ajaxReturn("1","eval");
     }
     else
       {
         $this->ajaxReturn($n->getError(),"eval")
       }
}

在我们平时做验证的时候,很少会用ajax,相对来说比较麻烦,我们用简单的js就可以完成的,比如我做一个关于邮箱的验证,在jsdongtai.html中加入这一句

<div><input type="text" id="email"/><span id="aa"></span></div>

然后我们开始做邮箱的验证了,我用的js都是引入的jquery包,前面已经引入过了,这里就不再详说了

<script type="text/javascript">

$("#email").blur(function(){
   var email = $(this).val();
   $zz=/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/;
  if(email.match($zz)==null)
  {
    $("#aa").html("邮箱格式不正确");    
  }
  else
  {
     $("#aa").html("邮箱验证成功");  
  }
})
</script>
PHP 相关文章推荐
自己前几天写的无限分类类
Feb 14 PHP
PHP 遍历XP文件夹下所有文件
Nov 27 PHP
php 搜索框提示(自动完成)实例代码
Feb 05 PHP
php中隐形字符65279(utf-8的BOM头)问题
Aug 16 PHP
php通过隐藏表单控件获取到前两个页面的url
Sep 09 PHP
php微信支付之APP支付方法
Mar 04 PHP
深入理解PHP之OpCode原理详解
Jun 01 PHP
PHP中for循环与foreach的区别
Mar 06 PHP
php生成毫秒时间戳的实例讲解
Sep 22 PHP
PHP使用curl_multi_select解决curl_multi网页假死问题的方法
Aug 15 PHP
PHP与以太坊交互详解
Aug 24 PHP
Laravel框架自定义公共函数的引入操作示例
Apr 16 PHP
ThinkPHP 模板引擎使用详解
May 07 #PHP
php中Ioc(控制反转)和Di(依赖注入)
May 07 #PHP
Laravel中任务调度console使用方法小结
May 07 #PHP
Laravel实现表单提交
May 07 #PHP
Laravel实现autoload方法详解
May 07 #PHP
PHP中include和require的区别实例分析
May 07 #PHP
自制PHP框架之设计模式
May 07 #PHP
You might like
Codeigniter出现错误提示Error with CACHE directory的解决方案
2014/06/12 PHP
PHP调用其他文件中的类
2018/04/02 PHP
JSON 客户端和服务器端的格式转换
2009/08/27 Javascript
基于jQuery的淡入淡出可自动切换的幻灯插件
2010/08/24 Javascript
js Event对象的5种坐标
2011/09/12 Javascript
JS鼠标事件大全 推荐收藏
2011/11/01 Javascript
不用构造函数(Constructor)new关键字也能实现JavaScript的面向对象
2013/01/11 Javascript
javascript中的return和闭包函数浅析
2014/06/06 Javascript
js中document.write的那点事
2014/12/12 Javascript
jquery实现勾选复选框触发事件给input赋值
2015/02/01 Javascript
jQuery搜索同辈元素方法
2015/02/10 Javascript
深入理解JavaScript系列(45):代码复用模式(避免篇)详解
2015/03/04 Javascript
第六章之辅组类与响应式工具
2016/04/25 Javascript
利用Angular.js限制textarea输入的字数
2016/10/20 Javascript
获取JavaScript异步函数的返回值
2016/12/21 Javascript
深入学习jQuery中的data()
2016/12/22 Javascript
JavaScript实现的商品抢购倒计时功能示例
2017/04/17 Javascript
解决Vue-cli npm run build生产环境打包,本地不能打开的问题
2018/09/20 Javascript
jQuery pagination分页示例详解
2018/10/23 jQuery
在node环境下parse Smarty模板的使用示例代码
2019/11/15 Javascript
vuex的数据渲染与修改浅析
2020/11/26 Vue.js
js 执行上下文和作用域的相关总结
2021/02/08 Javascript
python下函数参数的传递(参数带星号的说明)
2010/09/19 Python
Python multiprocessing.Manager介绍和实例(进程间共享数据)
2014/11/21 Python
使用python装饰器计算函数运行时间的实例
2018/04/21 Python
基于Python 中函数的 收集参数 机制
2019/12/21 Python
python 多线程共享全局变量的优劣
2020/09/24 Python
pytorch 中forward 的用法与解释说明
2021/02/26 Python
Europcar英国:英国汽车和货车租赁
2017/01/21 全球购物
微软新西兰官方网站:Microsoft New Zealand
2018/08/17 全球购物
花坛标语大全
2014/06/30 职场文书
群众路线领导对照材料
2014/08/23 职场文书
宿舍卫生管理制度
2015/08/05 职场文书
城镇居民医疗保险工作总结
2015/08/10 职场文书
jquery插件实现搜索历史
2021/04/24 jQuery
分享很少见很有用的SQL功能CORRESPONDING
2022/08/05 MySQL