js 实现 pring_r功能

// JavaScript Document
var SYS=function(){}
SYS._print_r=function($v,$left,$ret){
	    if(typeof $left ===‘undefined‘){
			$left = -1;
		}
		 if(typeof $ret ===‘undefined‘){
			$ret = "My";
		}
		$left+=1;
		if (typeof $v ===‘object‘ ){
			return SYS.arrayToString($v,$left,$ret);
		}
		return   $ret+$v+"\n";
	}

	SYS.arrayToString=function($v,$left,$ret){
			$ret+="Array\n"+str_repeat(‘  ‘,$left*4)+"(\n";
			for ($key in $v)
			{
				$parmret=$ret+str_repeat(‘  ‘,$left*4+2)+"["+$key+"] => ";
				$ret=SYS.recursionPrintR($v[$key],$left,$parmret)	;
			}
			 $ret+=str_repeat(‘  ‘,$left*4)+")\n\n";
		 return $ret;
	}

//递归调用_print_r
	SYS.recursionPrintR=function($val,$left,$ret){
		if (typeof $val ===‘object‘){
			return SYS._print_r($val,$left,$ret);
		}
			return $ret+‘<div style="border:1px #eee solid; width:auto;padding:5px;‘

			+‘ left:‘+($left*50+100)+‘px;position:relative; height:20px; overflow-y:hidden; " ‘
			+‘ onClick=" ‘
			+‘ "   ><span onClick="window.SYS.ch.apply(this.parentNode,[1])">[+]</span><span onClick="window.SYS.ch.apply(this.parentNode,[-1])">[-]</span>‘+$val+‘</div>\n‘;
	}
	SYS.print_r=function($v,$left,$ret){
		 if(typeof $left ===‘undefined‘){
			$left = -1;
		}
		 if(typeof $ret ===‘undefined‘){
			$ret = "My";
		}
	    return ‘<pre>‘+SYS._print_r($v,$left,$ret)+‘</pre>‘;
	}
SYS.ch=function(sign){
	var h=this.style.height;
	h=(h.replace(/px/, ‘‘)) ;
	this.style.height=(parseInt(h)+sign*100)+‘px‘
	} 

function str_repeat($str,$num,$cn){
	if(typeof $cn ==="undefined"){
	    $cn = 0 ;
	}
    $cn=$cn+1;
    if($num==0){return "";}
    else
    {$temp=$str;}
    return $num>$cn ? $temp+str_repeat($str,$num,$cn) : $temp;
}

  注意:这里的不是数组是object.如果要输出数组请把判断类型改为 array

调用:这里的THREE指的是 three.js中的对象

SYS.print_r(THREE)

时间: 2024-10-13 22:24:56

js 实现 pring_r功能的相关文章

js实现照片墙功能

用javascript实现的照片墙功能:DEMO下载 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="Content-Type" content="textml; charset=utf-8" /> <title>photo

JS全选功能代码优化

最近在看javascript MVC那本书,也感觉到自己写的代码也并不优雅,所以一直在想 用另一种模式来编写JS代码,所以针对之前的简单的JS全选功能来做个简单的demo,使用目前现在的编码方式来重新编码,当然以后会一直用这种方式来编写自己的代码.下面是如下代码: JS所有代码: /** * JS全选 * @class Checkall * @param {Object} cfg * @param {Element|selector} [cfg.container] 限定全选的容器 * @par

不用js实现幻灯片功能

one two three four five six seven eight 不用js实现幻灯片功能,布布扣,bubuko.com

js 实现打印功能

前端js实现打印功能的两种方式: 1.利用iframe,隐藏iframe,直接通过按钮直接打印,弹出打印设置页面. <button onclick="doPrint();">print</button> <iframe style="display:none" id="printIframe" frameBorder=0 scrolling=no width="100%" src="./

js实现ArrayList功能

1.ArrayList方法摘要 构造方法摘要 ArrayList() 构造一个初始容量为 10 的空列表. ArrayList(Collection<? extends E> c) 构造一个包含指定 collection 的元素的列表,这些元素是按照该 collection 的迭代器返回它们的顺序排列的. ArrayList(int initialCapacity) 构造一个具有指定初始容量的空列表. 方法摘要 boolean add(E e) 将指定的元素添加到此列表的尾部. void ad

JS实现注销功能

JS实现注销功能,代码如下: 1 <script> 2 window.history.forward(1); 3 </script> 这个代码的用法就是: 比如,我们此时有两个页面:Login.html 和 Index.html 我们要实现从 Login.html 登陆到 Index.html 注销的话,那么,就把代码放到 Index.html 页面 简单来说,在那个页面注销,就将这个代码放到哪个页面,我在Index.html注销,所以,将代码放到Index.html .

C#后台程序与HTML页面中JS方法互调(功能类似于Ajax中的DWR)

此方法适用于 C#中嵌入WebBrowser(浏览器) 通过浏览器中加载的页面与C#的后台代码进行交互. 一.C#程序 1.在C#窗体中添加WebBrowser(浏览器),将页面的URL添加到浏览器中. 2.窗体代码添加 using System.Runtime.InteropServices;//和Html页面交互使用 在类的上一行添加 [ComVisible(true)]//和Html页面交互使用 在类的构造其中添加 this.webB.ObjectForScripting = this;

JS实现倒计时功能

上午主要编写了倒计时的功能,用了两种算法,一种是最终秒数.分钟数.小时数减去当前的秒.分钟和小时,当然要重点注意的就是借位的问题.另一种算法就是将最终时间转换成秒数,当前时间转换成秒数,相减之后再换算成小时.分钟和秒,再分别显示出来. 下面是我编写的代码: 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title

node.js实现CURL功能

PHP中的CURL功能很好实现,直接四五行代码封装一下就OK了.node.js中如何实现CURL的功能呢,下面详细介绍. 这里需要用到request这个库,所以先安装此包: npm install request 安装下来之后, 就是代码实现的问题了.示例代码如下(只实现了POST方法): var request = require('request'); request.post( { url:'http://hovertree.com:9095/phpTest.php', form:{ us