设为首页收藏本站关注微信<<< 抵制 IE6 人人有责 >>>
搜索
热搜: 活动 交友 discuz
查看: 2565|回复: 3
打印 上一主题 下一主题

[dedecms] dedecms的一些代码(备用)

[复制链接]
跳转到指定楼层
楼主
发表于 2017-3-29 16:16:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
dedecms 调用指定栏目,指定作者,指定自定义字段
模板里调用SQL:
[HTML] 纯文本查看 复制代码
{dede:sql sql="select a.id,a.title,a.writer,a.pubdate,a.typeid,b.aid,b.sex from dede_archives a LEFT JOIN dede_addonarticle b on b.aid=a.id where a.typeid='7' and a.writer=~writer~ and b.sex='男' order by a.pubdate desc LIMIT 0,5"}
            <li>文章ID:[field:id/]</li>
            <li>标题:<a href="[field:id function='GetOneDocUrl(@me)'/]">[field:title/]</a></li>
            <li>作者:[field:writer/]</li>
            <li>性别:[field:sex/]</li>
          {/dede:sql}


a.typeid=7   调用ID为7的栏目  如果不需要指定栏目ID  那么你可以把 a.typeid='7' and  删掉
a.writer=~writer~  调用当前文章的作者,调用指定的作者,可以这样写a.writer='admin'  这样就是指定调用admin这个作者的文档
b.sex=男  设置性别,也就是自定义字段。如果你的自定义字段不是sex 那么你只要把sql里的b.sex 改成你的字段,例如 name 改成b.name
LIMIT 0,5  设置要调用的条数,我这里写的是5条,自行修改.

指定调用2个栏目的话  可以把where a.typeid='7'  修改为 where a.typeid='7' and a.typeid='8'
这样就指定调用栏目ID 为 7和8的栏目

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享淘帖
回复

使用道具 举报

沙发
 楼主| 发表于 2017-3-29 16:18:11 | 只看该作者
dedecms 会员中心调用最后登录时间和IP
在会员中心的任意模板中可以调用以下自定义函数
[PHP] 纯文本查看 复制代码
<?php echo login_time_ip($cfg_ml->M_ID);?>


将以下函数放到include/extend.func.php 文件中
[PHP] 纯文本查看 复制代码
function login_time_ip($mid)
{
global $dsql; 
$row = $dsql->GetOne("SELECT mid,logintime,loginip FROM `dede_member` where mid='$mid'");
$msg="最后登录时间:".MyDate('Y-m-d H:i:s',$row['logintime']).",上次登录IP:".$row['loginip'];   
return $msg;
    }




就可以调用了,非常简单。


回复 支持 反对

使用道具 举报

板凳
 楼主| 发表于 2017-3-29 16:18:11 | 只看该作者
栏目增加图片
include\taglib\channel.lib.php
增加 arcpic 字段
首页调用
[HTML] 纯文本查看 复制代码
{dede:channel typeid=9 currentstyle=""}
[field:arcpic/]
{/dede:channel}


回复 支持 反对

使用道具 举报

地板
 楼主| 发表于 2017-3-29 16:18:11 | 只看该作者
dedecms 开发点赞功能

首先后台执行SQL
[SQL] 纯文本查看 复制代码
ALTER TABLE dede_archives ADD zan int(11) NOT NULL DEFAULT '0' AFTER weight;



也就是在 dede_archives 表中增加 zan  这个字段,加到weight这个字段后边。

然后执行

[SQL] 纯文本查看 复制代码
CREATE TABLE IF NOT EXISTS `dede_zan` ( 
  `id` int(11) NOT NULL AUTO_INCREMENT, 
  `aid` int(11) NOT NULL, 
  `ip` varchar(40) NOT NULL, 
  PRIMARY KEY (`id`) 
) ENGINE=MyISAM  DEFAULT CHARSET=utf8



这个表是保存被赞的文档aid 及IP的,为了检测是否赞过的IP

然后在include/extend.func.php 中增加以下函数,用来获取文档被赞次数的

[PHP] 纯文本查看 复制代码
function zan($aid)
{
    global $dsql;
    $row = $dsql->GetOne("Select id,zan From dede_archives where id='".$aid."'");
    return $row['zan'];
    }



打开模板templets/default/article_article.htm

加入css

[CSS] 纯文本查看 复制代码
.zan p{
background:#000; opacity:.8;filter:alpha(opacity=80);} 
.zan p a{padding-left:30px; height:24px; background:url(/images/heart.png) no-repeat  
4px -1px;color:#fff; font-weight:bold; font-size:14px} 
.zan p a:hover{background-position:4px -25px;text-decoration:none}



加入JS,记得引入jquery.js
<script type="text/javascript" src="/jquery.js"></script>

[JavaScript] 纯文本查看 复制代码
$(function(){ 
    $("p a").click(function(){ 
        var zan = $(this); 
        var id = zan.attr("rel"); //对应id 
        zan.fadeOut(300); //渐隐效果 
        $.ajax({ 
            type:"POST", 
            url:"/zan.php", 
            data:"id="+id, 
            cache:false, //不缓存此页面 
            success:function(data){ 
                zan.html(data); 
                zan.fadeIn(300); //渐显效果 
            } 
        }); 
        return false; 
    }); 
});



加入:
[HTML] 纯文本查看 复制代码
<div class="zan"><p><a href="#"  
title="赞一个 "class="img_on" rel="{dede:field.id/}">{dede:field.id function="zan(@me)"/}</a></p></div>



建立zan.php 放到根目录
[PHP] 纯文本查看 复制代码
<?php
require_once (dirname(__FILE__) . "/include/common.inc.php");
$ip =getip(); //获取用户IP 
$id = $_POST['id']; 
if(!isset($id) || empty($id)) exit; 
 
//查询已赞过的IP
$dsql->SetQuery("SELECT ip FROM dede_zan  WHERE aid='".$id."' and ip='$ip'");
$dsql->Execute();
$count = $dsql->GetTotalRow();
 
if($count==0){ //如果没有记录 
 
    $dsql->ExecuteNoneQuery("update dede_archives set zan=zan+1 where id='$id'; ");//写入赞数
    
    $dsql->ExecuteNoneQuery("insert into dede_zan (aid,ip) values ('$id','$ip'); ");//写入IP,及被赞的AID 
 
    $rows = $dsql->GetOne("Select zan  from dede_archives where id='".$id."'");//获取被赞的数量
    $zan = $rows['zan']; //获取赞数值 
    echo $zan; 
}else{ 
    echo "赞过了.."; 
}


好了,点赞功能开发好了。

回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

QQ|手机版|Archiver|源于生活(个人生活娱乐工作的笔记)css3,html5,学习笔记    

GMT+8, 2024-11-23 17:18 , Processed in 0.140400 second(s), 26 queries .

Powered by Mr.Kevin-ying

© 2004-2015

快速回复 返回顶部 返回列表