thinkphp修改及编写标签库,编辑器的使用
在view目录下创建Index_aaa.html
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>select</title></head><body><tagLib name="html"/><html:select options="address" selected="sh" values="address"/></body></html>
public function aaa(){$this->assign("address",["sh"=> "上海","天津","北京","郑州"]);$this->display();}



public function _ms($tag) {$name = $tag['name'];$options = $tag['options'];$id = $tag['id'];$selected = $tag['selected'];$parseStr = '<select id="'.$id.'" name="'.$name.'" >';$parseStr .='<?php foreach($'.$options.' as $val) { ?>';$parseStr .='<?php if("'.$selected.'"==$val) { ?>';$parseStr .= '<option selected="selected" value="<?php echo $val ?>"><?php echo $val ?></option>';$parseStr .= '<?php } else { ?><option value="<?php echo $val ?>"><?php echo $val ?></option>';$parseStr .= '<?php } ?>';$parseStr .= '<?php } ?>';$parseStr .= '</select>';return $parseStr;}
public function _ms($tag) {$name = $tag['name'];$options = $tag['options'];$id = $tag['id'];$selected = $tag['selected'];$parseStr = '<select id="'.$id.'" name="'.$name.'" >';$parseStr .='<?php foreach($'.$options.' as $val) { ?>';/* $parseStr .='<?php if("'.$selected.'"==$val) { ?>';*///selected的值可以随便写$parseStr .='<?php if($'.$selected.'==$val) { ?>';//值可以先分配再写$parseStr .= '<option selected="selected" value="<?php echo $val ?>"><?php echo $val ?></option>';$parseStr .= '<?php } else { ?><option value="<?php echo $val ?>"><?php echo $val ?></option>';$parseStr .= '<?php } ?>';$parseStr .= '<?php } ?>';$parseStr .= '</select>';return $parseStr;}
public function aaa(){$this->assign("address",["上海","天津","北京","郑州"]);$this->assign("sh","天津");$this->display();}
<tagLib name="html"/><html:ms id="aa" name="uu" options="address" selected="sh"/><br>

public function _select($tag) {$name = $tag['name'];$options = $tag['options'];$values = $tag['values'];$output = $tag['output'];$multiple = $tag['multiple'];$id = $tag['id'];$size = $tag['size'];$first = $tag['first'];$selected = $tag['selected'];$style = $tag['style'];$ondblclick = $tag['dblclick'];$onchange = $tag['change'];if(!empty($multiple)) {$parseStr = '<select id="'.$id.'" name="'.$name.'" ondblclick="'.$ondblclick.'" onchange="'.$onchange.'" multiple="multiple" class="'.$style.'" size="'.$size.'" >';}else {$parseStr = '<select id="'.$id.'" name="'.$name.'" onchange="'.$onchange.'" ondblclick="'.$ondblclick.'" class="'.$style.'" >';}if(!empty($first)) {$parseStr .= '<option value="" >'.$first.'</option>';}if(!empty($options)) {$parseStr .= '<?php foreach($'.$options.' as $key=>$val) { ?>';if(!empty($selected)) {$parseStr .= '<?php if(!empty($'.$selected.') && ($'.$selected.' == $val || in_array($key,$'.$selected.'))) { ?>';$parseStr .= '<option selected="selected" value="<?php echo $val ?>"><?php echo $val ?></option>';$parseStr .= '<?php }else { ?><option value="<?php echo $val ?>"><?php echo $val ?></option>';$parseStr .= '<?php } ?>';}else {$parseStr .= '<option value="<?php echo $val ?>"><?php echo $val ?></option>';}$parseStr .= '<?php } ?>';}else if(!empty($values)) {$parseStr .= '<?php for($i=0;$i<count($'.$values.');$i++) { ?>';if(!empty($selected)) {$parseStr .= '<?php if(isset($'.$selected.') && ((is_string($'.$selected.') && $'.$selected.' == $'.$values.'[$i]) || (is_array($'.$selected.') && in_array($'.$values.'[$i],$'.$selected.')))) { ?>';$parseStr .= '<option selected="selected" value="<?php echo $'.$values.'[$i] ?>"><?php echo $'.$output.'[$i] ?></option>';$parseStr .= '<?php }else { ?><option value="<?php echo $'.$values.'[$i] ?>"><?php echo $'.$output.'[$i] ?></option>';$parseStr .= '<?php } ?>';}else {$parseStr .= '<option value="<?php echo $'.$values.'[$i] ?>"><?php echo $'.$output.'[$i] ?></option>';}$parseStr .= '<?php } ?>';}$parseStr .= '</select>';return $parseStr;}
window.UEDITOR_HOME_URL = "/Public/js/ueditor/";

$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>';
<tagLib name="html"/><html:editor type="UEDITOR"></html:editor>
thinkphp修改及编写标签库,编辑器的使用的更多相关文章
- thinkphp 标签库
内置的模板引擎除了支持普通变量的输出之外,更强大的地方在于标签库功能. 标签库类似于Java的Struts中的JSP标签库,每一个标签库是一个独立的标签库文件,标签库中的每一个标签完成某个功能,采用X ...
- jsp程序设计:jstl之JSTL标签库
转载自:http://www.blogjava.net/haizhige/archive/2008/10/26/236783.html,个人进行了一些修改. 前言:写一个taglib一般可以继承Sim ...
- java-自定义标签&&JSTL标签库详解
自定义标签是Jav aWeb的一部分非常重要的核心功能,我们之前就说过,JSP规范说的很清楚,就是Jsp页面中禁止编写一行Java代码,就是最好不要有Java脚本片段,下面就来看一下自定义标签的简介: ...
- JavaWeb学习篇之----自定义标签&&JSTL标签库详解
今天来看一下自定义标签的内容,自定义标签是JavaWeb的一部分非常重要的核心功能,我们之前就说过,JSP规范说的很清楚,就是Jsp页面中禁止编写一行Java代码,就是最好不要有Java脚本片段,下面 ...
- ThinkPHP3.2.3 自定义标签库的使用
ThinkPHP 3.2.3 手册中标签库驱动的地址是: http://www.kancloud.cn/manual/thinkphp/1859 标签库的地址是:http://www.kancloud ...
- 学习笔记_Java_day13_JSTL_自定义标签库(9)
自定义标签 1 自定义标签概述 1.1 自定义标签的步骤 其实我们在JSP页面中使用标签就等于调用某个对象的某个方法一样,例如:<c:if test=””>,这就是在调用对象的方法一样.自 ...
- jsp的标签库和自定义标签
1.jstl标签库 JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应用的通用核心功能. JSTL支持通用的.结构化的任务,比如迭代,条件判断,XML文档操作,国际化标签,SQL标签. ...
- 十、JSTL标签库
l JSTL标签库(重点) l 自定义标签(理解) l MVC设计模式(重点中的重点) l Java三层框架(重点中的重点) JSTL标签库 1 什么是JSTL JSTL是apache对EL表达式 ...
- EL表达式、JSTL标签库
一.EL(Expression Language)表达式 语法结构:${var} 若要停用对EL表达式的评估的话,需要使用page指令将isELIgnored属性值设为true: <%@ pag ...
随机推荐
- 深入浅出SQL Server中的死锁
简介 死锁的本质是一种僵持状态,是多个主体对于资源的争用而导致的.理解死锁首先需要对死锁所涉及的相关观念有一个理解. 一些基础知识 要理解SQL Server中的死锁,更好的方式是通过类比从更大的面理 ...
- 【原创】刚刚发现的SVN的几个有用的功能
一.可看到一个文件/目录跨Branch的所有变更历程 二.SVN可自动利用Word2013的审阅功能对比docx文档
- WebService异常时,查看请求状态码方法
/// <summary> /// Test 的摘要说明 /// </summary> [WebService(Namespace = "http://tempuri ...
- Jquery:hide一个元素,需要注意的问题(offset)
$(".load_more").css('display','none'); 或 $(that.more).find("strong").hide(); 需要注 ...
- 高通AR增强现实Unity3D
AR: 增强现实,台湾翻译叫做扩张实境 1.注册.然后下载sdk(注册账号主要是为了第3步中制作识别图而用的) 下载地址:https://developer.vuforia.com/resources ...
- nodejs单元测试
前言: 之前一直听说过单元测试,但是具体怎么做,也没有深入研究,感觉测试是一件很麻烦的事,花费时间.可能是自己太懒了,一看到测试那么多陌生的东西就不想弄了. 然后一拖再拖,直到最近,换了一家公司,然后 ...
- DSET收集ESXi硬件日志
1.Open DSET CLI with administrator mode C:\Windows\system32>dellsysteminfo -s 10.125.1.xxx -u roo ...
- 循环语句--for
1.guess_age优化版v1.py #coding=utf-8 age = 22 for i in range(10): if i < 3: guess_num = int(input('i ...
- linux下对进程按照内存使用情况进行排序
linux下对进程按照内存使用情况进行排序的命令为:ps aux --sort -rss 详细解说参见 http://alvinalexander.com/linux/unix-linux-proce ...
- 【巩固】Bootstrap笔记一
这两天开始重新巩固一下bootstrap的学习,群里有朋友介绍说麦子学院的教程不错,特地看了一下,有2个项目练习,所以跟着做了一下,下面开始笔记. <button class="nav ...