dedecms 标签 global(dedecms标签文档)

在DedeCMS这个强大的内容管理系统里,标签功能是其中一大亮点,它可以帮助我们轻松实现各种页面效果。而其中,有一个叫做“global”的标签,它具有全局变量的管理功能,今天,我们就来聊聊这个神秘的“global”标签。

一、什么是DedeCMS标签global?

我们先来了解一下什么是DedeCMS标签global。在DedeCMS中,标签global是一个用于获取全局变量的标签,它可以将全局变量在页面中直接使用,无需再次调用数据库或其他方式获取。

二、global标签的使用场景

1. 页面标题设置:在网站中,我们通常需要设置统一的页面标题,这时就可以使用global标签来获取全局变量中的标题。

2. 网站版权信息:在网站底部,我们通常需要展示网站的版权信息,这时也可以使用global标签来获取全局变量中的版权信息。

3. 网站SEO优化:在网站SEO优化过程中,我们需要在页面中添加一些关键词,这时可以使用global标签来获取全局变量中的关键词。

4. 网站导航栏:在网站导航栏中,我们需要展示网站的所有栏目,这时可以使用global标签来获取全局变量中的栏目信息。

三、global标签的使用方法

下面,我们以一个简单的例子来展示如何使用global标签。

示例:获取全局变量中的网站标题,并显示在页面中。

“`html

{dede:global.title/}

“`

这里,`{dede:global.title/}`就是global标签的使用方法。其中,`title`是全局变量中的标题名称。

四、global标签的常见全局变量

下面,我们列举一些常见的全局变量,方便大家在使用global标签时进行参考。

全局变量名称 说明
title 页面标题
keywords 网站关键词
description 网站描述
siteurl 网站域名
sitepath 网站路径
sitename 网站名称
copyright 网站版权信息
legalinfo 网站法律声明

五、global标签的优势

1. 简化代码:使用global标签可以简化代码,减少重复调用数据库或其他方式获取全局变量的操作。

2. 提高效率:global标签可以直接从全局变量中获取所需信息,无需再次查询数据库,从而提高页面加载速度。

3. 易于维护:当需要修改全局变量时,只需在系统设置中进行修改,无需修改页面代码,方便维护。

六、总结

DedeCMS标签global是一个强大的全局变量管理工具,它可以帮助我们轻松实现各种页面效果。通过本文的介绍,相信大家对global标签有了更深入的了解。在实际应用中,我们可以根据需求灵活运用global标签,提高网站开发效率。

注意:在使用global标签时,请注意全局变量的命名规范,以免出现错误。合理运用global标签,可以使网站更加美观、高效。

dedecms5.7调用图片出现严重失真,缩略图显示严重变形

首先在网站后台系统中设置网站缩略图尺寸大小和模板中调用图片最大尺寸相同.

再打开文件include/helpers/extend.helpes.php在最下面加上以下代码

if(! function_exists('thumb'))

{

function thumb($imgurl,$width,$height,$bg= true)

{

global$cfg_mainsite,$cfg_multi_site;

$thumb= eregi(“http://”,$imgurl)?str_replace($cfg_mainsite,'',$imgurl):$imgurl;

list($thumbname,$extname)= explode('.',$thumb);

$newthumb=$thumbname.'_'.$width.'_'.$height.'.'.$extname;

if(!$thumbname||!$extname||!file_exists(DEDEROOT.$thumb)) return$imgurl;

if(!file_exists(DEDEROOT.$newthumb))

{

include_once DEDEINC.'/image.func.php';

if($bg==true)

{

ImageResizeNew(DEDEROOT.$thumb,$width,$height, DEDEROOT.$newthumb);

}

else

{

ImageResize(DEDEROOT.$thumb,$width,$height, DEDEROOT.$newthumb);

}

}

return$cfg_multi_site=='Y'?$cfg_mainsite.$newthumb:$newthumb;

}

}

调用方法:

标签: [field:picname function='thumb(@me,$width,$height,$bg)'/]

参数说明:

$width:缩略图宽度(整数)

$height:缩略图高度(整数)

$bg:是否用空白填补,默认自动填补,背景填充颜色在系统-附件设置里(true/false)

举例:

调用长宽为100像素的缩略图:[field:picname function='thumb(@me,100,100)'/]

保留原有比例,不自动填充(不建议):[field:picname function='thumb(@me,100,100,false)'/]

再到 include/helpers/image.helpes.php中写入以下代码

/**

*缩图片自动生成函数,来源支持bmp、gif、jpg、png

*但生成的小图只用jpg或png格式

*@access public

*@param string$srcFile图片路径

*@param string$toW转换到的宽度

*@param string$toH转换到的高度

*@param string$toFile输出文件到

*@return string

*/

if(! function_exists('ImageResize'))

{

function ImageResize($srcFile,$toW,$toH,$toFile=””)

{

global$cfg_photo_type;

if($toFile==””)

{

$toFile=$srcFile;

}

$info=””;

$srcInfo= GetImageSize($srcFile,$info);

switch($srcInfo[2])

{

case 1:

if(!$cfg_photo_type['gif'])

{

return false;

}

$im= imagecreatefromgif($srcFile);

break;

case 2:

if(!$cfg_photo_type['jpeg'])

{

return false;

}

$im= imagecreatefromjpeg($srcFile);

break;

case 3:

if(!$cfg_photo_type['png'])

{

return false;

}

$im= imagecreatefrompng($srcFile);

break;

case 6:

if(!$cfg_photo_type['bmp'])

{

return false;

}

$im= imagecreatefromwbmp($srcFile);

break;

}

$srcW=ImageSX($im);

$srcH=ImageSY($im);

if($srcW<=$toW&&$srcH<=$toH)

{

return true;

}

//缩略生成并裁剪

$newW=$toH*$srcW/$srcH;

$newH=$toW*$srcH/$srcW;

if($newH>=$toH)

{

$ftoW=$toW;

$ftoH=$newH;

}

else

{

$ftoW=$newW;

$ftoH=$toH;

}

if($srcW>$toW||$srcH>$toH)

{

if(function_exists(“imagecreatetruecolor”))

{

@$ni= imagecreatetruecolor($ftoW,$ftoH);

if($ni)

{

imagecopyresampled($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH);

}

else

{

$ni=imagecreate($ftoW,$ftoH);

imagecopyresized($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH);

}

}

else

{

$ni=imagecreate($ftoW,$ftoH);

imagecopyresized($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH);

}

//裁剪图片成标准缩略图

$new_imgx= imagecreatetruecolor($toW,$toH);

if($newH>=$toH)

{

imagecopyresampled($new_imgx,$ni,0,0,0,($newH-$toH)/2,$toW,$toH,$toW,$toH);

}

else

{

imagecopyresampled($new_imgx,$ni,0,0,($newW-$toW)/2,0,$toW,$toH,$toW,$toH);

}

switch($srcInfo[2])

{

case 1:

imagegif($new_imgx,$toFile);

break;

case 2:

imagejpeg($new_imgx,$toFile,85);

break;

case 3:

imagepng($new_imgx,$toFile);

break;

case 6:

imagebmp($new_imgx,$toFile);

break;

default:

return false;

}

imagedestroy($new_imgx);

imagedestroy($ni);

}

imagedestroy($im);

return true;

}

}

即可

QQ:51461981

dedecms列表调用内容多张图片

普通文章列表调用内容多张图片不能用图集模型的办法,需要自己写一个函数,在include/extend.func.php增加函数

functionGetpic($body)

{

$getpic='';

preg_match_all(“/(src)=[\”|'|]{0,}([^>]*\.(gif|jpg|bmp|png))/isU”,$body,$img_array);

$img_array=array_unique($img_array[2]);

if(count($img_array)>0)

{

foreach($img_arrayas$key=>$value)

{

$picname=preg_replace(“/[\”|'|]{1,}/”,'',$value);

$getpic.=”<p><imgsrc='”.$picname.”'border=0/></p>”;

}

}

else

{

$getpic=”<p>没有图片</p>”;

}

return$getpic;

}

列表页模版使用标签

{dede:listpagesize='10'addfields='body'}

<li><ahref='[field:arcurl/]'target='_blank'>

<spanclass=”title”>[field:title/]</span>

[field:bodyfunction='Getpic(@me)'/]

</a></li>

{/dede:list}

同时到网站后台-内容模型管理,修改普通文章模型附加列表字段增加body

保存后,就可以更新列表了,这样就能在列表页显示文章正文内所有图片

dedecms数据库,用php调用sql最新文章

这是我之前写的一个类,和你的需求基本一样,你拿去自己改改吧

<?php

$GLOBALS['web_channel_dir']='dir/inc';

//设置系统根路径

define('WEB_ROOT',$GLOBALS['web_channel_dir']? substr(dirname(__FILE__), 0,- strlen($GLOBALS['web_channel_dir'])): dirname(__FILE__).'/');

abstract class BaseDataQuery

{

/*

*构造方法

*/

function __construct($pid,$cid,$xid)

{

if(!file_exists(WEB_ROOT.'data/common.inc.php'))

{

echo”配置错误”;

exit();

}else{

require_once WEB_ROOT.'data/common.inc.php';

}

$this->cfg_dbhost=$cfg_dbhost;

$this->cfg_dbname=$cfg_dbname;

$this->cfg_dbuser=$cfg_dbuser;

$this->cfg_dbpwd=$cfg_dbpwd;

$this->cfg_dbprefix=$cfg_dbprefix;

$this->cfg_db_language=$cfg_db_language;

$this->link=$this->connect();

}

function connect()

{

//global$link,$host,$dbuser,$dbpasswd,$db;

$link= mysql_connect($this->cfg_dbhost,$this->cfg_dbuser,$this->cfg_dbpwd) or

die(“Could not connect:”. mysql_error().””.$sql);

mysql_select_db($this->cfg_dbname);

mysql_query(“SET NAMES UTF8”);//设置数据库的要查询结果的字符集

return$link;

}

function Query($sql)

{

if(!$this->link)

$this->link=$this->connect();

$result= mysql_query($sql,$this->link) or

die(“Could not query:”. mysql_error().””.$sql);

return$result;

}

function getAll($sql)

{

$res=$this->Query($sql);

if($res!== false)

{

$arr= array();

while($row= mysql_fetch_assoc($res))

{

$arr[]=$row;

}

return$arr;

}

else

{

return false;

}

}

function getAll_cache($sql)

{

$res=$this->Query($sql);

if($res!== false)

{

$arr= array();

while($row= mysql_fetch_assoc($res))

{

$arr[]=$row;

}

return$arr;

}

else

{

return false;

}

}

function getOne($sql,$limited= false)

{

if($limited== true)

{

$sql= trim($sql.' LIMIT 1');

}

$res=$this->Query($sql);

if($res!== false)

{

$row= mysql_fetch_row($res);

if($row!== false)

{

return$row[0];

}

else

{

return'';

}

}

else

{

return false;

}

}

/**

*得到子栏目ID

*$reid上线id

*/

function get_child($reid)

{

$child_sql=”SELECT id FROM dede_arctype WHERE reid=”.$reid;

$res=$this->getAll($child_sql);

if(empty($res)){

return$reid;

}

foreach($res AS$row)

{

if(!empty($row['id']))

{

$arr[]=$row['id'];

$this->get_child($row['id']);

}

}

$str= join(“,”,$arr);

return$str;

}

/**

*得到子栏目名称与id

*$reid上级id

*/

function get_child_name($reid)

{

$child_sql=”SELECT id,typename,reid FROM dede_arctype WHERE reid=”.$reid;

$res=$this->getAll($child_sql);

return$res;

}

function get_ic_name($id)

{

$child_sql=”SELECT typename FROM dede_arctype WHERE id=”.$id;

$res=$this->getAll($child_sql);

return$res;

}

/*

*数据查询

*$flag(需要查询的标记例头条[h]推荐[c]幻灯[f]特荐[a]滚动[s]加粗[b]图片[p]跳转[j])

*$typeid需要查询的栏目id(22,23,24,25)

*$len需要查询的数据长度如果$len是数据就是limit 1,100形式如果是字符就是limit 100如果$len不存就是不限止条数

**/

function query_data($queryInfo)

{

$queryInfo['flag']?$flag=$queryInfo['flag']:$flag= false;

$typeid=$queryInfo['typeid'];

$queryInfo['len']?$len=$queryInfo['len']:$len= false;

$field=$queryInfo['field'];

$queryInfo['order']?$order=$queryInfo['order']:$order= false;

$queryInfo['channel']?$channel=$queryInfo['channel']:$channel= false;

$queryInfo['where']?$where=” AND”.$queryInfo['where']:$where=””;

$queryInfo['typeid2']?$typeid2=”AND typeid2 in(“.$queryInfo['typeid2'].”)”:$typeid2=””;

$queryInfo['table']?$table=$queryInfo['table']:$table=”dede_archives”;

//定义查询数据标识(头条,图片,推荐)

if($flag)

{

$flag=”and find_in_set('$flag',flag)”;

}else{

$flag=””;

}

//查询条数

if($len)

{

if(is_array($len))

{

$len=”limit”.$len[0].”,”.$len[1];

}else{

$len=”limit 0,”.$len;

}

}else{

$len=””;

}

//定义排序条件

if(isset($order)&& is_array($order))

{

$orderarr= array();

foreach($order as$key=>$value)

{

$orderarr[]=$key.””.$value;

}

$orderstr= join(“,”,$orderarr);

}

elseif($order=='rand')

{

$orderstr=” rand(),id desc”;

}

elseif($order!='')

{

$orderstr=$order;

}

else

{

$orderstr=”pubdate desc”;

//$orderstr=$order;

}

//定义查询模型

if($channel)

{

$channel=”AND channel=”.$channel;

}elseif($channel==”null”){

$channel=””;

}

else

{

$channel=”AND channel= 1″;

}

//定义查询字段

if($field)

{

if(is_array($field))

{

$field= join(“,”,$field);

}

$sql=”select”.$field.” from”.$table.” WHERE arcrank>-1 and typeid in(“.$typeid.”)”.$typeid2.$flag.””.$channel.”$where ORDER BY”.$orderstr.””.$len;

}else{

//根剧栏目查询新闻

$sql=”select id,title,pubdate from”.$table.” WHERE arcrank>-2 and typeid in(“.$typeid.”)”.$typeid2.$flag.””.$channel.”$where ORDER BY”.$orderstr.””.$len;

//echo”<br/>”;

}

if($queryInfo['debug']){

$debugstr=”this is Debug:[$sql ]”;

return$debugstr;

}

$result=$this->getAll($sql);

return$result;

}

}

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享