在view目录下创建Index_aaa.html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>select</title>
  6. </head>
  7. <body>
  8. <tagLib name="html"/>
  9. <html:select options="address" selected="sh" values="address"/>
  10. </body>
  11. </html>
在IndexController.class.php里面编写函数
  1. public function aaa(){
  2. $this->assign("address",["sh"=> "上海","天津","北京","郑州"]);
  3. $this->display();
  4. }

修改此文件可以编写标签库

把输出的几项全部改为val即可解决values='0'
的问题,让values的值等于option的值

编写新的标签
      'ms'=>array('attr'=>'id,name,options,selected','close'=>0)  
<html:ms id="aa" name="uu" options="address" selected="北京"/><br> 
修改后的代码selected的值可以随便写即可
 
  1. public function _ms($tag) {
  2. $name = $tag['name'];
  3. $options = $tag['options'];
  4. $id = $tag['id'];
  5. $selected = $tag['selected'];
  6. $parseStr = '<select id="'.$id.'" name="'.$name.'" >';
  7. $parseStr .='<?php foreach($'.$options.' as $val) { ?>';
  8. $parseStr .='<?php if("'.$selected.'"==$val) { ?>';
  9. $parseStr .= '<option selected="selected" value="<?php echo $val ?>"><?php echo $val ?></option>';
  10. $parseStr .= '<?php } else { ?><option value="<?php echo $val ?>"><?php echo $val ?></option>';
  11. $parseStr .= '<?php } ?>';
  12. $parseStr .= '<?php } ?>';
  13. $parseStr .= '</select>';
  14. return $parseStr;
  15. }
可以根据分配的值来确定selected
  1. public function _ms($tag) {
  2. $name = $tag['name'];
  3. $options = $tag['options'];
  4. $id = $tag['id'];
  5. $selected = $tag['selected'];
  6. $parseStr = '<select id="'.$id.'" name="'.$name.'" >';
  7. $parseStr .='<?php foreach($'.$options.' as $val) { ?>';
  8. /* $parseStr .='<?php if("'.$selected.'"==$val) { ?>';*///selected的值可以随便写
  9. $parseStr .='<?php if($'.$selected.'==$val) { ?>';//值可以先分配再写
  10. $parseStr .= '<option selected="selected" value="<?php echo $val ?>"><?php echo $val ?></option>';
  11. $parseStr .= '<?php } else { ?><option value="<?php echo $val ?>"><?php echo $val ?></option>';
  12. $parseStr .= '<?php } ?>';
  13. $parseStr .= '<?php } ?>';
  14. $parseStr .= '</select>';
  15. return $parseStr;
  16. }
  1. public function aaa(){
  2. $this->assign("address",["上海","天津","北京","郑州"]);
  3. $this->assign("sh","天津");
  4. $this->display();
  5. }
  1. <tagLib name="html"/>
  2. <html:ms id="aa" name="uu" options="address" selected="sh"/><br>
用框架本身带的也可以实现

把红线处的$key修改为$val用分配变量的方式也可以实现selected,系统自带的稍加修改,但是值不可以随便写在selected后
  1. public function _select($tag) {
  2. $name = $tag['name'];
  3. $options = $tag['options'];
  4. $values = $tag['values'];
  5. $output = $tag['output'];
  6. $multiple = $tag['multiple'];
  7. $id = $tag['id'];
  8. $size = $tag['size'];
  9. $first = $tag['first'];
  10. $selected = $tag['selected'];
  11. $style = $tag['style'];
  12. $ondblclick = $tag['dblclick'];
  13. $onchange = $tag['change'];
  14. if(!empty($multiple)) {
  15. $parseStr = '<select id="'.$id.'" name="'.$name.'" ondblclick="'.$ondblclick.'" onchange="'.$onchange.'" multiple="multiple" class="'.$style.'" size="'.$size.'" >';
  16. }else {
  17. $parseStr = '<select id="'.$id.'" name="'.$name.'" onchange="'.$onchange.'" ondblclick="'.$ondblclick.'" class="'.$style.'" >';
  18. }
  19. if(!empty($first)) {
  20. $parseStr .= '<option value="" >'.$first.'</option>';
  21. }
  22. if(!empty($options)) {
  23. $parseStr .= '<?php foreach($'.$options.' as $key=>$val) { ?>';
  24. if(!empty($selected)) {
  25. $parseStr .= '<?php if(!empty($'.$selected.') && ($'.$selected.' == $val || in_array($key,$'.$selected.'))) { ?>';
  26. $parseStr .= '<option selected="selected" value="<?php echo $val ?>"><?php echo $val ?></option>';
  27. $parseStr .= '<?php }else { ?><option value="<?php echo $val ?>"><?php echo $val ?></option>';
  28. $parseStr .= '<?php } ?>';
  29. }else {
  30. $parseStr .= '<option value="<?php echo $val ?>"><?php echo $val ?></option>';
  31. }
  32. $parseStr .= '<?php } ?>';
  33. }else if(!empty($values)) {
  34. $parseStr .= '<?php for($i=0;$i<count($'.$values.');$i++) { ?>';
  35. if(!empty($selected)) {
  36. $parseStr .= '<?php if(isset($'.$selected.') && ((is_string($'.$selected.') && $'.$selected.' == $'.$values.'[$i]) || (is_array($'.$selected.') && in_array($'.$values.'[$i],$'.$selected.')))) { ?>';
  37. $parseStr .= '<option selected="selected" value="<?php echo $'.$values.'[$i] ?>"><?php echo $'.$output.'[$i] ?></option>';
  38. $parseStr .= '<?php }else { ?><option value="<?php echo $'.$values.'[$i] ?>"><?php echo $'.$output.'[$i] ?></option>';
  39. $parseStr .= '<?php } ?>';
  40. }else {
  41. $parseStr .= '<option value="<?php echo $'.$values.'[$i] ?>"><?php echo $'.$output.'[$i] ?></option>';
  42. }
  43. $parseStr .= '<?php } ?>';
  44. }
  45. $parseStr .= '</select>';
  46. return $parseStr;
  47. }
引入ueditor放在js里面修改ueditor.config.js为如下的代码
  1. window.UEDITOR_HOME_URL = "/Public/js/ueditor/";


thinkphp里面放百度编辑器
  1. $parseStr = '<script id="container" name="content" type="text/plain">这里写你的初始化内容</script><script type="text/javascript" src="__ROOT__/Public/js/ueditor/ueditor.config.js"></script><script type="text/javascript" src="__ROOT__/Public/js/ueditor/ueditor.all.js"></script><script type="text/javascript"> var ue = UE.getEditor("container",{emotionLocalization:true,lang:"zh-cn",initialFrameWidth:"80%",initialFrameHeight:320,textarea:"content",initialContent:"欢迎留言!", autoClearinitialContent:true}); </script>';
然后在Index_aaa.html 里面编写要显示的代码
  1. <tagLib name="html"/>
  2. <html:editor type="UEDITOR"></html:editor>




thinkphp修改及编写标签库,编辑器的使用的更多相关文章

  1. thinkphp 标签库

    内置的模板引擎除了支持普通变量的输出之外,更强大的地方在于标签库功能. 标签库类似于Java的Struts中的JSP标签库,每一个标签库是一个独立的标签库文件,标签库中的每一个标签完成某个功能,采用X ...

  2. jsp程序设计:jstl之JSTL标签库

    转载自:http://www.blogjava.net/haizhige/archive/2008/10/26/236783.html,个人进行了一些修改. 前言:写一个taglib一般可以继承Sim ...

  3. java-自定义标签&&JSTL标签库详解

    自定义标签是Jav aWeb的一部分非常重要的核心功能,我们之前就说过,JSP规范说的很清楚,就是Jsp页面中禁止编写一行Java代码,就是最好不要有Java脚本片段,下面就来看一下自定义标签的简介: ...

  4. JavaWeb学习篇之----自定义标签&&JSTL标签库详解

    今天来看一下自定义标签的内容,自定义标签是JavaWeb的一部分非常重要的核心功能,我们之前就说过,JSP规范说的很清楚,就是Jsp页面中禁止编写一行Java代码,就是最好不要有Java脚本片段,下面 ...

  5. ThinkPHP3.2.3 自定义标签库的使用

    ThinkPHP 3.2.3 手册中标签库驱动的地址是: http://www.kancloud.cn/manual/thinkphp/1859 标签库的地址是:http://www.kancloud ...

  6. 学习笔记_Java_day13_JSTL_自定义标签库(9)

    自定义标签 1 自定义标签概述 1.1 自定义标签的步骤 其实我们在JSP页面中使用标签就等于调用某个对象的某个方法一样,例如:<c:if test=””>,这就是在调用对象的方法一样.自 ...

  7. jsp的标签库和自定义标签

    1.jstl标签库 JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应用的通用核心功能. JSTL支持通用的.结构化的任务,比如迭代,条件判断,XML文档操作,国际化标签,SQL标签. ...

  8. 十、JSTL标签库

      l JSTL标签库(重点) l 自定义标签(理解) l MVC设计模式(重点中的重点) l Java三层框架(重点中的重点) JSTL标签库 1 什么是JSTL JSTL是apache对EL表达式 ...

  9. EL表达式、JSTL标签库

    一.EL(Expression Language)表达式 语法结构:${var} 若要停用对EL表达式的评估的话,需要使用page指令将isELIgnored属性值设为true: <%@ pag ...

随机推荐

  1. mybatis与 Exception

    mybatis将所有的异常全部包成了运行时异常,减少在高层代码中频繁的try-catch导致的代码臃肿问题.Persistence是它们共有的父类,继承自RuntimeException非检查型异常. ...

  2. zabbix3.0安装【server】

    关于zabbix的介绍,就不多说了,功能强大,架构前卫,自己直接去官网研究 在这里,还是秉承研究一个应用或者技术,都要自己动手安装部署,实战操作,才能深入掌握,基于这个精神,zabbix从安装部署开始 ...

  3. UISegmentedControl和UIStepper的使用

    UISegmentedControl:分栏控件,常用的属性和方法是 1.tintColor:控制分栏控件的颜色风格 2.insertSegmentWithTitle(Image):插入分栏标题(图片) ...

  4. git常用命令 (阿里云code)

    命令行指令 Git 全局设置 git config --global user.name "马会东" git config --global user.email "ma ...

  5. IQueryable,IEnumerable,List相互转换

    发个文记录一下犯的错误吧!!! 如果在使用ASP.NET MVC很多的数据存取都是以IQueryable<>泛型类接收,那么在做两个IQueryable<>集合拼接时对于新手可 ...

  6. Python使用struct处理二进制

    有的时候需要用python处理二进制数据,比如,存取文件,socket操作时.这时候,可以使用python的struct模块来完成.可以用 struct来处理c语言中的结构体. struct模块中最重 ...

  7. 【学】React的学习之旅2 - React Component的生命周期

    分成三个状态: Mounted Update Unmounted Mounted:当我们看到组件在浏览器中从无到有的效果的时候,mounted已经结束了,这个组件已经被mounted了 有这个阶段有2 ...

  8. GridLookUpEdit多列模糊查询最简单方式 z

    GridLookUpEdit的知识库是RepositoryItemGridLookUpEdit,切确的说GridLookUpEdit只是RepositoryItemGridLookUpEdit的一个壳 ...

  9. [AS3.0] NetConnection.Connect.Rejected 解决办法

    以下是运用FMS录制视频的一段代码: package { import flash.display.Sprite; import flash.events.AsyncErrorEvent; impor ...

  10. (转)设计模式_Singleton单例模式

    静态初始化 public sealed class Singleton { private static readonly Singleton instance = new Singleton(); ...