2013年4月

DedeCms autoindex和itemindex 用法说明,让dedecms autoindex,itemindex 从0到1开始的办法
让dedecms autoindex,itemindex 从0到1开始的办法
[field:global name=autoindex runphp="yes"]@me=@me+1;[/field:global]
{dede:global name=itemindex runphp="yes"}@me=@me+1;{/dede:global}

autoindex itemindex 的使用心得区别
channelartlist 标签下使用 {dede:global name='itemindex' runphp='yes'}@me;{/dede:global}
自增1
arclist 标签下使用 [field:global.autoindex/] 默认从1开始
channel 标签下使用 [field:global.autoindex/] 默认从0开始
channelartlist 标签下使用 {dede:global.itemindex/} 默认从1开始

arclist 从0开始[field:global name=autoindex runphp="yes"]@me=@me-1;[/field:global]
channel 从1开始[field:global name=autoindex runphp="yes"]@me=@me+1;[/field:global][field:typename/]
channelartlist 从0开始{dede:global name=itemindex runphp='yes'}@me=@me-1;{/dede:global}

<div id="h_pd_lm_{dede:global.itemindex/}" {dede:global name='itemindex' runphp='yes'}@me=(@me==1)?'':'style="display:none;"';{/dede:global} class="pd2_lmc_l1"> 

channelartlist实例

{dede:channelartlist  notypeid='123,124,146,147'}  
<a class="pd2_lmt{dede:global name=itemindex runphp='yes'}@me=(@me==1)?'1':'3';{/dede:global}" onmouseover="showitem2({dede:global name=itemindex runphp='yes'}@me=@me-1;{/dede:global},'pd_lm','h_pd_lm_','pd2_lmt');" href='{dede:field name='typeurl'/}'>  
{dede:php}if($refObj->Fields['ispart']){echo $refObj->Fields['typename'];}{/dede:php}  
</a>  
{/dede:channelartlist}

标签下使用 [field:global name=autoindex/]
channel实例

{dede:channel titlelen='32'}  
<li [field:global name='autoindex' runphp='yes']if(@me%2==0){@me='class="rr"';}else{@me='';}[/field:global] ><h3><a href='[field:typelink/]'>[field:typename/]</a></h3></li>  
{/dede:channel}

在arclist中使用autoindex runphp 时用这种方式:

{dede:arclist titlelen='22' row='4' flag='c' orderby='id'}  
<a href="[field:arcurl /]" target="_blank">[field:title /]</a>  
[field:global name='autoindex' runphp='yes']if(@me==2){@me="<br />";}else{@me=' ';}[/field:global]{/dede:arclist}

自增1
[field:global.autoindex/]
arclist实例

{dede:arclist channelid=17 row=6 orderby=pubdate titlelen=40 addfields='docphoto,docjob,doctec' typeid='123,136,146,155,172,182,202'}  
<div id="h_nrr_zj_[field:global.autoindex/]" class="nrr_zjl" [field:global name='autoindex' runphp='yes']if(@me==1){@me="";}else{@me='style="display:none;"';}[/field:global] >  
 <div><a href="[field:arcurl/]" title="[field:fulltitle/]" target="_blank"><img src="[field:litpic/]" alt="[field:fulltitle/]" /></a></div>  
</div>  
{/dede:arclist}

如何自由定义 开始的数字
autoindex/itemindex 可以使用 @me+1;实现由指定数字开始
遇到类似的问题做下这个笔记,在用到的时候可以灵活发挥!
list 标签下试用autoindex

{dede:list pagesize='40' orderby='id'}  
[field:global name='autoindex' runphp='yes']if(@me%10==0){@me="test";}else{@me='';}[/field:global]   
{/dede:list}

今天在做项目的时候遇到问题,要获取上一篇、下一篇的URL地址,系统默认是带链的,要的效果是这样的。 "/anzhuang/2011/1012/555.html"
代码如下:
上一篇地址
{dede:prenext get='pro' runphp="yes"}
preg_match_all('/<a.*?(?: |\\t|\\r|\\n)?href=[\'"]?(.+?)[\'"]?(?:(?: |\\t|\\r|\\n)+.*?)?>(.+?)<\/a.*?>/sim', @me, $strResult, PREG_PATTERN_ORDER);
@me=$strResult[1][0];
{/dede:prenext}
下一篇地址
{dede:prenext get='next' runphp="yes"}
preg_match_all('/<a.*?(?: |\\t|\\r|\\n)?href=[\'"]?(.+?)[\'"]?(?:(?: |\\t|\\r|\\n)+.*?)?>(.+?)<\/a.*?>/sim', @me, $strResult, PREG_PATTERN_ORDER);
@me=$strResult[1][0];
{/dede:prenext}

在使用channel来调子栏目的时候,指定 “type=son typeid=x” 发现currentstyle无效:

{dede: type='son' typeid='12' currentstyle="<li class='thisclass'><a href='~typelink~' title="~typename~">~typename~</a> </li>"}
<li><a title="[field:typename/]" href="[field:typelink/]">[field:typename/]</a></li>
{/dede:channel}

解决的办法:

{dede:channel type='son'  currentstyle="<li class='thisclass'><a href='~typelink~' title="~typename~">~typename~</a> </li>"}
<li><a title="[field:typename/]" href="[field:typelink/]">[field:typename/]</a></li>
{/dede:channel}

另外,这样也是可以的
把typeid=‘12’改为channel=‘1’ (文章模型id),首页除外,其他页面不需要指定typeid=x,会自动判断当前位置.

{dede: type='son' channel='1' currentstyle="<li class='thisclass'><a href='~typelink~' title="~typename~">~typename~</a> </li>"}
<li><a title="[field:typename/]" href="[field:typelink/]">[field:typename/]</a></li>
{/dede:channel}

来源网络

[field:pubdate function=GetDateMK(@me)/] 2009-11-10
[field:pubdate function=GetDateTimeMK(@me)/] 2009-11-10 12:20:20
[field:pubdate function="GetDateMK(@me)"/] 2009-11-10
[field:pubdate function="GetDateTimeMK(@me)"/] 2009-11-10 12:20:20
[field:pubdate function=MyDate('m-d',@me)/] 11-10
{dede:field.pubdate function="MyDate('Y-m-d H:i',@me)"/} 2009-11-10 12:20

来源:吾爱IT网
不废话直接上代码

/*   
用途:检查输入的Email信箱格式是否正确   
输入:strEmail:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function checkEmail(strEmail)    
{   
    //var emailReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/;    
    var emailReg = /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/;   
    if ( emailReg.test(strEmail) ) {   
        return true;   
    }   
    else {   
        alert("您输入的Email地址格式不正确!");   
        return false;   
    }   
};   
    
/*
用途:校验ip地址的格式   
输入:strIP:ip地址   
返回:如果通过验证返回true,否则返回false;   
*/  
function isIP(strIP)    
{   
    if (isNull(strIP)) {   
        return false;   
    }   
    var re = /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式    
    if (re.test(strIP)) {   
        if ( RegExp.$1 < 256 && RegExp.$2 < 256 && RegExp.$3 < 256 && RegExp.$4 < 256) {   
            return true;   
        }   
    }   
    return false;   
};   
    
/* 
用途:检查输入手机号码是否正确   
输入:strMobile:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function checkMobile( strMobile )   
{   
    var regu = /^[1][3][0-9]{9}$/;   
    var re = new RegExp(regu);   
    if (re.test(strMobile)) {   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:检查输入的电话号码格式是否正确   
输入:strPhone:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function checkPhone( strPhone )    
{   
    var phoneRegWithArea = /^[0][1-9]{2,3}-[0-9]{5,10}$/;   
    var phoneRegNoArea = /^[1-9]{1}[0-9]{5,8}$/;   
    var prompt = "您输入的电话号码不正确!" if ( strPhone.length > 9 ) {   
        if ( phoneRegWithArea.test(strPhone) ) {   
            return true;   
        }   
        else {   
            alert( prompt );   
            return false;   
        }   
    }   
    else {   
        if ( phoneRegNoArea.test( strPhone ) ) {   
            return true;   
        }   
        else {   
            alert( prompt );   
            return false;   
        }   
    }   
};   
    
/* 
用途:检查输入字符串是否为空或者全部都是空格   
输入:str   
返回:如果全是空返回true,否则返回false   
*/  
function isNull( str )   
{   
    if ( str == "" ) {   
        return true;   
    }   
    var regu = "^[ ]+$";   
    var re = new RegExp(regu);   
    return re.test(str);   
};   
    
/* 
用途:检查输入对象的值是否符合整数格式   
输入:str 输入的字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isInteger( str )   
{   
    var regu = /^[-]{0,1}[0-9]{1,}$/;   
    return regu.test(str);   
};   
    
/* 
用途:检查输入字符串是否符合正整数格式   
输入:s:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isNumber( s )   
{   
    var regu = "^[0-9]+$";   
    var re = new RegExp(regu);   
    if (s.search(re) != - 1) {   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:检查输入字符串是否是带小数的数字格式,可以是负数   
输入:str:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isDecimal( str )   
{   
    if (isInteger(str)) {   
        return true;   
    }   
    var re = /^[-]{0,1}(\d+)[\.]+(\d+)$/;   
    if (re.test(str)) {   
        if (RegExp.$1 == 0 && RegExp.$2 == 0) {   
            return false;   
        }   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:检查输入对象的值是否符合端口号格式   
输入:str 输入的字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isPort( str )   
{   
    return (isNumber(str) && str < 65536);   
};   
    
/* 
用途:检查输入字符串是否符合金额格式,格式定义为带小数的正数,小数点后最多三位   
输入:s:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isMoney( s )   
{   
    var regu = "^[0-9]+[\.][0-9]{0,3}$";   
    var re = new RegExp(regu);   
    if (re.test(s)) {   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:检查输入字符串是否只由英文字母和数字和下划线组成   
输入:s:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isNumberOr_Letter( s )   
{   
    //判断是否是数字或字母    
    var regu = "^[0-9a-zA-Z\_]+$";   
    var re = new RegExp(regu);   
    if (re.test(s)) {   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:检查输入字符串是否只由英文字母和数字组成   
输入:s:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isNumberOrLetter( s )   
{   
    //判断是否是数字或字母    
    var regu = "^[0-9a-zA-Z]+$";   
    var re = new RegExp(regu);   
    if (re.test(s)) {   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:检查输入字符串是否只由汉字、字母、数字组成   
输入:s:字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isChinaOrNumbOrLett( s )   
{   
    //判断是否是汉字、字母、数字组成    
    var regu = "^[0-9a-zA-Z\u4e00-\u9fa5]+$";   
    var re = new RegExp(regu);   
    if (re.test(s)) {   
        return true;   
    }   
    else {   
        return false;   
    }   
};   
    
/* 
用途:判断是否是日期   
输入:date:日期;fmt:日期格式   
返回:如果通过验证返回true,否则返回false   
*/  
function isDate( date, fmt )    
{   
    if (fmt == null) {   
        fmt = "yyyyMMdd";   
    }   
    var yIndex = fmt.indexOf("yyyy");   
    if (yIndex ==- 1) {   
        return false;   
    }   
    var year = date.substring(yIndex, yIndex + 4);   
    var mIndex = fmt.indexOf("MM");   
    if (mIndex ==- 1) {   
        return false;   
    }   
    var month = date.substring(mIndex, mIndex + 2);   
    var dIndex = fmt.indexOf("dd");   
    if (dIndex ==- 1) {   
        return false;   
    }   
    var day = date.substring(dIndex, dIndex + 2);   
    if (!isNumber(year) || year > "2100" || year < "1900") {   
        return false;   
    }   
    if (!isNumber(month) || month > "12" || month < "01") {   
        return false;   
    }   
    if (day > getMaxDay(year, month) || day < "01") {   
        return false;   
    }   
    return true;   
};   
function getMaxDay(year, month)    
{   
    if (month == 4 || month == 6 || month == 9 || month == 11) {   
        return "30";   
    }   
    if (month == 2) {   
        if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {   
            return "29";   
        }   
        else {   
            return "28";   
        }   
        return "31";;   
    }   
};   
    
/* 
用途:字符1是否以字符串2结束   
输入:str1:字符串;str2:被包含的字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isLastMatch(str1, str2)    
{   
    var index = str1.lastIndexOf(str2);   
    if (str1.length == index + str2.length) {   
        return true;   
    }   
    return false;   
};   
    
/* 
用途:字符1是否以字符串2开始   
输入:str1:字符串;str2:被包含的字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isFirstMatch(str1, str2)    
{   
    var index = str1.indexOf(str2);   
    if (index == 0) {   
        return true;   
    }   
    return false;   
};   
    
/* 
用途:字符1是包含字符串2   
输入:str1:字符串;str2:被包含的字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function isMatch(str1, str2)    
{   
    var index = str1.indexOf(str2);   
    if (index ==- 1) {   
        return false;   
    }   
    return true;   
};   
    
/* 
用途:检查输入的起止日期是否正确,规则为两个日期的格式正确,且结束如期>=起始日期   
输入:startDate:起始日期,字符串; endDate:结束如期,字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function checkTwoDate( startDate, endDate )    
{   
    if ( !isDate(startDate) ) {   
        alert("起始日期不正确!");   
        return false;   
    }   
    else if ( !isDate(endDate) ) {   
        alert("终止日期不正确!");   
        return false;   
    }   
    else if ( startDate > endDate ) {   
        alert("起始日期不能大于终止日期!");   
        return false;   
    }   
    return true;   
};   
    
/* 
用途:检查复选框被选中的数目   
输入:checkboxID:字符串   
返回:返回该复选框中被选中的数目   
*/  
function checkSelect( checkboxID )    
{   
    var check = 0;   
    var i = 0;   
    if ( document.all(checkboxID).length > 0 )    
    {   
        for ( i = 0; i < document.all(checkboxID).length; i++ ) {   
            if ( document.all(checkboxID).item( i ).checked ) {   
                check += 1;   
            }   
        }   
    }   
    else {   
        if ( document.all(checkboxID).checked ) {   
            check = 1;   
        }   
    }   
    return check;   
}   
function getTotalBytes(varField)    
{   
    if (varField == null) {   
        return - 1;   
    }   
    var totalCount = 0;   
    for (i = 0; i < varField.value.length; i++) {   
        if (varField.value.charCodeAt(i) > 127) {   
            totalCount += 2;   
        }   
        else {   
            totalCount++ ;   
        }   
    }   
    return totalCount;   
}   
function getFirstSelectedValue( checkboxID )   
{   
    var value = null;   
    var i = 0;   
    if ( document.all(checkboxID).length > 0 )   
    {   
        for ( i = 0; i < document.all(checkboxID).length; i++ )   
        {   
            if ( document.all(checkboxID).item( i ).checked ) {   
                value = document.all(checkboxID).item(i).value;   
                break;   
            }   
        }   
    }   
    else {   
        if ( document.all(checkboxID).checked ) {   
            value = document.all(checkboxID).value;   
        }   
    }   
    return value;   
}   
function getFirstSelectedIndex( checkboxID )   
{   
    var value = - 2;   
    var i = 0;   
    if ( document.all(checkboxID).length > 0 )   
    {   
        for ( i = 0; i < document.all(checkboxID).length; i++ ) {   
            if ( document.all(checkboxID).item( i ).checked ) {   
                value = i;   
                break;   
            }   
        }   
    }   
    else {   
        if ( document.all(checkboxID).checked ) {   
            value = - 1;   
        }   
    }   
    return value;   
}   
function selectAll( checkboxID, status )   
{   
    if ( document.all(checkboxID) == null) {   
        return;   
    }   
    if ( document.all(checkboxID).length > 0 )   
    {   
        for ( i = 0; i < document.all(checkboxID).length; i++ ) {   
            document.all(checkboxID).item( i ).checked = status;   
        }   
    }   
    else {   
        document.all(checkboxID).checked = status;   
    }   
}   
function selectInverse( checkboxID )    
{   
    if ( document.all(checkboxID) == null) {   
        return;   
    }   
    if ( document.all(checkboxID).length > 0 )    
    {   
        for ( i = 0; i < document.all(checkboxID).length; i++ )    
        {   
            document.all(checkboxID).item( i ).checked = !document.all(checkboxID).item( i ).checked;   
        }   
    }   
    else {   
        document.all(checkboxID).checked = !document.all(checkboxID).checked;   
    }   
}   
function checkDate( value )    
{   
    if (value == '') {   
        return true;   
    }   
    if (value.length != 8 || !isNumber(value)) {   
        return false;   
    }   
    var year = value.substring(0, 4);   
    if (year > "2100" || year < "1900") {   
        return false;   
    }   
    var month = value.substring(4, 6);   
    if (month > "12" || month < "01") {   
        return false;   
    }   
    var day = value.substring(6, 8);   
    if (day > getMaxDay(year, month) || day < "01") {   
        return false;   
    }   
    return true;   
};   
    
/* 
用途:检查输入的起止日期是否正确,规则为两个日期的格式正确或都为空且结束日期>=起始日期   
输入:startDate:起始日期,字符串; endDate: 结束日期,字符串   
返回:如果通过验证返回true,否则返回false   
*/  
function checkPeriod( startDate, endDate )    
{   
    if ( !checkDate(startDate) ) {   
        alert("起始日期不正确!");   
        return false;   
    }   
    else if ( !checkDate(endDate) ) {   
        alert("终止日期不正确!");   
        return false;   
    }   
    else if ( startDate > endDate ) {   
        alert("起始日期不能大于终止日期!");   
        return false;   
    }   
    return true;   
};   
    
/* 
用途:检查证券代码是否正确   
输入:secCode:证券代码   
返回:如果通过验证返回true,否则返回false   
*/  
function checkSecCode( secCode )    
{   
    if ( secCode.length != 6 ) {   
        alert("证券代码长度应该为6位");   
        return false;   
    }   
    if (!isNumber( secCode ) ) {   
        alert("证券代码只能包含数字");   
        return false;   
    }   
    return true;   
};   
    
/*
function:cTrim(sInputString,iType)   
description:字符串去空格的函数   
parameters:iType:1=去掉字符串左边的空格;2=去掉字符串左边的空格;0=去掉字符串左边和右边的空格   
return value:去掉空格的字符串   
*/  
function cTrim(sInputString, iType)    
{   
    var sTmpStr = ' ';   
    var i = - 1;   
    if (iType == 0 || iType == 1)    
    {   
        while (sTmpStr == ' ') {   
            ++i;   
            sTmpStr = sInputString.substr(i, 1);   
        }   
        sInputString = sInputString.substring(i);   
    }   
    if (iType == 0 || iType == 2)    
    {   
        sTmpStr = ' ';   
        i = sInputString.length;   
        while (sTmpStr == ' ') {   
            --i;   
            sTmpStr = sInputString.substr(i, 1);   
        }   
        sInputString = sInputString.substring(0, i + 1);   
    }   
    return sInputString;   
};  

作者文章地址:http://www.52its.net/articles/615.html