⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 togglepre.js

📁 WPF星型网状拓扑图绘制 WPF星型网状拓扑图绘制
💻 JS
字号:
var MinPreHeight = 450;
var MinPreChars  = 750;

var PreOpen = new Image();
var PreClose = new Image();
PreOpen.src="/images/plus.gif";
PreClose.src="/images/minus.gif";

function togglePre()
{
	var id = this.getAttribute("preid");
	var preelm = document.getElementById("pre" + id);
	var imgelm = document.getElementById("preimg" + id);
	var togelm = document.getElementById("precollapse" + id);

	if (preelm.style.display != 'none') 
	{
		if (document.all) togelm.innerText = " Expand code snippet";
		else 
		{
			document.getElementById("premain" + id).className = "precollapse";
			togelm.firstChild.nodeValue = " Expand code snippet";
		}
		preelm.style.display = 'none';
		imgelm.setAttribute("src", PreOpen.src);
	}
	else 
	{
		if (document.all) togelm.innerText = " Collapse";
		else 
		{	
			document.getElementById("premain" + id).className = "SmallText";
			togelm.firstChild.nodeValue = " Collapse";
		}
		preelm.style.display = 'block';
		imgelm.setAttribute("src", PreClose.src);
	}
}

function InitTogglePre()
{
	var articleText = document.getElementById("contentdiv");
	if (!articleText) return;
	var pres = articleText.getElementsByTagName("pre");

	for (var i=0; i<pres.length; i++)
	{	
		var parent = pres[i].parentNode;			
			
		/*var wrap = document.createElement("div");
		wrap.className = "no-vmads";
		parent.insertBefore(wrap, pres[i]);
		var node = parent.removeChild(pres[i]);
		wrap.appendChild(node);	*/
		
		if (pres[i].offsetHeight == 0)
		{	if (pres[i].innerText.length < MinPreChars) continue; }
		else if (pres[i].offsetHeight < MinPreHeight)
			continue;
		
		var main = document.createElement("div");
		main.style.width="100%";
		main.setAttribute("id", "premain" + i.toString());

		var elm = document.createElement("img");
		elm.setAttribute("id", "preimg" + i.toString());
		elm.setAttribute("src", PreClose.src);
		if (document.all) elm.style.cursor = "pointer";
		elm.setAttribute("height", 9);
		elm.setAttribute("width", 9);
		elm.setAttribute("preid", i);
		elm.onclick = togglePre;

		main.appendChild(elm);	
	
		elm = document.createElement("span");
		elm.setAttribute("id", "precollapse" + i.toString());

		if (document.all)
		{
			main.className = "precollapse";
			elm.innerText = " Collapse";
			elm.style.cursor = "pointer";
		}
		else
		{
			main.className = "SmallText";
			//This is lame. Why can't W3C just allow innerText on spans??
			var new_el = document.createTextNode(" Collapse");
			
			main.style.cursor = "pointer";
			elm.appendChild(new_el);
		}
		
		elm.style.marginBottom = 0;
		elm.onclick = togglePre;
		elm.setAttribute("preid", i);
	
		main.appendChild(elm);
		
		//wrap.setAttribute("id", "pre" + i.toString());
		//wrap.style.marginTop = 0;
		pres[i].setAttribute("id", "pre" + i.toString());
		pres[i].style.marginTop = 0;
		
		var parent = pres[i].parentNode;
		parent.insertBefore(main, pres[i]);	
	}
}

InitTogglePre();

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -