Widget扩展一般用于页面组件的扩展。

先说明Widget被调用的方法,你只需要在你的模板文件中使用这样的语法:{:W("Demo/demo_widget_method",array(5,'thinkphp'))}

系统就会自动去寻找对应的Widget类文件并执行对应的方法。

具体步骤如下:

1.因为是直接在模板中写的{:W("Demo/demo_widget_method",array(5,'thinkphp'))},所以要了解后面的步骤,我们得移步系统的Template.class.php并看到了如下的东东

  1. /**
  2. * 模板标签解析
  3. * 格式: {TagName:args [|content] }
  4. * @access public
  5. * @param string $tagStr 标签内容
  6. * @return string
  7. */
  8. public function parseTag($tagStr){
  9. if(is_array($tagStr)) $tagStr = $tagStr[2];
  10. //if (MAGIC_QUOTES_GPC) {
  11. $tagStr = stripslashes($tagStr);
  12. //}
  13. //还原非模板标签
  14. if(preg_match('/^[\s|\d]/is',$tagStr))
  15. //过滤空格和数字打头的标签
  16. return C('TMPL_L_DELIM') . $tagStr .C('TMPL_R_DELIM');
  17. $flag   =  substr($tagStr,0,1);
  18. $flag2  =  substr($tagStr,1,1);
  19. $name   = substr($tagStr,1);
  20. if('$' == $flag && '.' != $flag2 && '(' != $flag2){ //解析模板变量 格式 {$varName}
  21. return $this->parseVar($name);
  22. }elseif('-' == $flag || '+'== $flag){ // 输出计算
  23. return  '<?php echo '.$flag.$name.';?>';
  24. }elseif(':' == $flag){ // 输出某个函数的结果
  25. return  '<?php echo '.$name.';?>';
  26. }elseif('~' == $flag){ // 执行某个函数
  27. return  '<?php '.$name.';?>';
  28. }elseif(substr($tagStr,0,2)=='//' || (substr($tagStr,0,2)=='/*' && substr(rtrim($tagStr),-2)=='*/')){
  29. //注释标签
  30. return '';
  31. }
  32. // 未识别的标签直接返回
  33. return C('TMPL_L_DELIM') . $tagStr .C('TMPL_R_DELIM');
  34. }

就在判断“:”的地方判断了模板中存在Widget的调用,经过方法前面的解析后的$name=W("Demo/demo_widget_method",array(5,'thinkphp'))

2.然后系统触发W()方法,此方法在系统目录下的Common/Functions.php中定义。

3.然后移步W()方法,几经周转,系统最后触发了DemoWidget.class.phpdemo_widget_method方法并传递了idname这两个参数

4.完毕

下面把上面的demo贴出

首先:(目录结构贴出如下)

IndexController.class.php的内容如下:

  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. class IndexController extends Controller {
  5. public function index(){
  6. $this->display();
  7. }
  8. }

Index控制器下的index方法的对应模板如下:

  1. <html>
  2. <head>
  3. <title>IndexController>Index</title>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. </head>
  7. <body>
  8. <h2>IndexController>Index</h2>
  9. {:W("Demo/demo_widget_method",array(5,'thinkphp'))}
  10. </body>
  11. </html>

DemoWidget.class.php的内容如下:

  1. <?php
  2. namespace Home\Widget;
  3. use Think\Controller;
  4. class DemoWidget extends Controller{
  5. public function demo_widget_method($id,$name){
  6. $this->assign('id',$id);
  7. $this->assign("name",$name);
  8. $this->display("Demo:demo_widget_method");
  9. }
  10. }

View/Demo/demo_widget_method.html模板内容如下:

  1. <h2>It is be show by DemoWidget/demo_widget_method</h2>
  2. <h2 style="color:red;">Id:{$id}</h2>
  3. <h2 style="color:red;">Name:{$name}</h2>

百看不如一练,不懂的就试试吧!

懂的话,恭喜你,我要像你学习!

ThinkPHP3.2.2 Widget扩展以及widget demo实例的更多相关文章

  1. ThinkPHP 3.2.3 Widget 扩展的使用

    ThinkPHP3.2.3 手册中 Widget 扩展的地址是: http://www.kancloud.cn/manual/thinkphp/1862 Widget 扩展一般用于页面组件的扩展,和自 ...

  2. thinkphp Widget扩展

    Widget扩展一般用于页面组件的扩展.大理石平台规格 举个例子,我们在页面中实现一个分类显示的Widget,首先我们要定义一个Widget控制器层 CateWidget,如下: namespace ...

  3. QT+常见控件+tab Widget 和Stacked Widget

    首先:这里介绍以下tab Widget 和Stacked Widget 之间的区别和使用的方法: tab Widget控件可以直接的进行切换,Stacked Widget却不可以直接在界面上进行切换, ...

  4. 【java】之 apache commons-codec 与Apache Digest demo实例,支持md5 sha1 base64 hmac urlencode

    使用commons-codec 进行加密的一些操作 package com.jiepu.ApacheDigest; import java.io.FileInputStream; import org ...

  5. 【xxl-job】轻松实现分布式定时任务demo实例

    [项目描述]前段时间专门独立了一个spring boot服务,用于做和第三方erp系统的对接工作.此服务的第一个需求工作就是可以通过不同的规则,设置不同的定时任务,从而获取erp系统的商品数据.所以, ...

  6. 给easyui datebox时间框控件扩展一个清空的实例

    给easyui datebox扩展一个清空的实例 步骤一:拓展插件 /** * 给时间框控件扩展一个清除的按钮 */ $.fn.datebox.defaults.cleanText = '清空'; ( ...

  7. 移动端页面弹幕小Demo实例说明

    代码地址如下:http://www.demodashi.com/demo/11595.html 弹幕小Demo实例地址,点击看效果 写在前面:尝试做了一下弹幕的实例,欢迎提出并指正问题 问题说明: D ...

  8. jetty demo实例启动

    Jetty是一个提供HHTP服务器.HTTP客户端和javax.servlet容器的开源项目.Jetty和tomcat相比,是轻量级服务器,支持热拔插,可扩展性大tomcat集成了很多功能,个性化瘦身 ...

  9. react目录结构、demo实例详解、属性数据绑定方式

    1.目录结构 2.demo实例详解 a)创建Home.js import React, { Component } from 'react'; //创建一个组件必须要集成Component组件,且组件 ...

随机推荐

  1. 几年前做家教写的C教程(之二)

    C语言学习宝典(2) 认识C语言中的运算符: (1)算术运算符   (+  -  *  /  %) (2)关系运算符    (>  <  ==  >=  <=  != ) (3 ...

  2. 【翻译十八】java-并发之锁对象

    Lock Objects Synchronized code relies on a simple kind of reentrant lock. This kind of lock is easy ...

  3. Spring XML配置文件示例(二)——web.xml

    <?xml version="1.0" encoding="UTF-8"?> <web-app id="WebApp_ID" ...

  4. Effective C++ 之 Item 6 : 若不想使用编译器自动生成的函数,就该明确拒绝

    Effective C++ chapter 2. 构造 / 析构 / 赋值运算 (Constructors, Destructors, and Assignment Operators) Item 6 ...

  5. 在Salesforce中处理Xml的生成与解析

    在Salesforce中处理Xml的生成与解析 1): Generate Xml private String ConvertAccountToXmlInfo(Account acc){ Dom.Do ...

  6. python学习第二天

    dict字典 把数据放入dict:直接赋值.初始化时指定 pop删除key set集合 add添加元素 remove删除元素 字符串str是不可变对象,对字符串的操作都会返回新的字符串 pass 什么 ...

  7. flex模拟微信布局

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  8. SQLServer 维护脚本分享(05)内存(Memory)

    --查看设置的最大最小每次 exec sp_configure 'max server memory (MB)' exec sp_configure 'min server memory (MB)' ...

  9. 大端模式 VS 小端模式

    简单点说,就是字节的存储顺序,如果数据都是单字节的,那怎么存储无所谓了,但是对于多字节数据,比如int,double等,就要考虑存储的顺序了.注意字节序是硬件层面的东西,对于软件来说通常是透明的.再说 ...

  10. AngularJS学习之HTML DOM

    1.AngularJS为HTML DOM元素的属性提供了绑定应用数据的指令: 2.ng-disabled指令:直接绑定应用程序数据到HTML的disable属性: <div ng-app=&qu ...