EMLOG图文轮播幻灯片

  • 内容
  • 相关
效果图:

123.png

教程如下:

代码是借助封装js代码msclass进行修改,需要修改三个文件:module.php,head.php,index.php或者log_list.php。具体代码修改如下:

一、在module .php文件底部加入如下代码

<?php
//slide数据源
        //定义函数,只有一个参数$num,即为调用的数据条数
function get_flash_data_img($num){
        //面向对象中静态方法实例化数据库对象(我是这么理解的)
        $db = MySql::getInstance();
        //下面是数据库语句,即获取gid,title,data,content等内容,非隐藏,时间正序,总共$num条数据
        $sql = "SELECT gid,title,content,date FROM ".DB_PREFIX."blog WHERE type='blog' and top='y' ORDER BY `top` DESC ,`date` DESC LIMIT 0,$num";
	$go = $db->query($sql);
                //开始循环进行显示
                while($row = $db->fetch_array($go)){
			$img_url = '';
                        //picthumb()函数为获取文章附件图片的函数,后面会补上
                        //如果附件中含有图片,那么$img_url就等于附件图片的地址
                        if(picthumb($row['gid'])){
				$img_url = picthumb($row['gid']);
                        //pin_thumb()函数为获取文章中图片链接的函数,后面会补上
                        //如果附件中不含图片,但是文章中有外链图片,则$img_url等于外链图片的地址
                        }elseif(pic_thumb($row['content'])){
				$img_url = pic_thumb($row['content']);
                        //如果以上两种情况都没有图片,那么$img_url就等于默认图片
                        //如下默认图片的路径是模板路径下images文件夹下的default_flash.jpg文件
                        }else{
				$img_url = TEMPLATE_URL.'images/default_flash.jpg';
			}
                        //下面这一句是非常关键的,$data即为我们上面步骤所说的数据
                        //第二步骤中我们知道格式为“<b><span style="color:#e53333;"><div><img src="图片地址1" stitle="标题名1" slink="链接地址1" /></div></span></b>”
                        //如下格式必须和上面步骤中提取出来的数据格式一致。如果是不同的幻灯片插件,只需此处的格式不同而已。
                        $data1 = '<li><img src="'.$img_url.'" stitle="'.$row['title'].'" slink="'.Url::log($row['gid']).'" /></li>';
						$data2 = '<li><a href="'.Url::log($row['gid']).'">'.$row['title'].'</a></li>';
                        //最后打印出数据,由于当前代码的位置是在while的循环体,因此会循环$num条数据
					 ?>
<li><a href="<?php echo Url::log($row['gid']); ?>"><img src="<?php echo $img_url; ?>" alt="<?php echo $row['title']; ?>" width="420" height="280" /></a></li>
		<?php } ?>
<?php } ?>
<?php
//slide数据源
        //定义函数,只有一个参数$num,即为调用的数据条数
function get_flash_data_art($num){
        //面向对象中静态方法实例化数据库对象(我是这么理解的)
        $db = MySql::getInstance();
        //下面是数据库语句,即获取gid,title,data,content等内容,非隐藏,时间正序,总共$num条数据
        $sql = "SELECT gid,title,content,date FROM ".DB_PREFIX."blog WHERE type='blog' and top='y' ORDER BY `top` DESC ,`date` DESC LIMIT 0,$num";
	$go = $db->query($sql);
                //开始循环进行显示
                while($row = $db->fetch_array($go)){
			$img_url = '';
                        //picthumb()函数为获取文章附件图片的函数,后面会补上
                        //如果附件中含有图片,那么$img_url就等于附件图片的地址
                        if(picthumb($row['gid'])){
				$img_url = picthumb($row['gid']);
                        //pin_thumb()函数为获取文章中图片链接的函数,后面会补上
                        //如果附件中不含图片,但是文章中有外链图片,则$img_url等于外链图片的地址
                        }elseif(pic_thumb($row['content'])){
				$img_url = pic_thumb($row['content']);
                        //如果以上两种情况都没有图片,那么$img_url就等于默认图片
                        //如下默认图片的路径是模板路径下images文件夹下的default_flash.jpg文件
                        }else{
				$img_url = TEMPLATE_URL.'images/default_flash.jpg';
			}
                        //下面这一句是非常关键的,$data即为我们上面步骤所说的数据
                        //第二步骤中我们知道格式为“<b><span style="color:#e53333;"><div><img src="图片地址1" stitle="标题名1" slink="链接地址1" /></div></span></b>”
                        //如下格式必须和上面步骤中提取出来的数据格式一致。如果是不同的幻灯片插件,只需此处的格式不同而已。
					$data1 = '<li><img src="'.$img_url.'" stitle="'.$row['title'].'" slink="'.Url::log($row['gid']).'"></li>';
						$data2 = '<li><a href="'.Url::log($row['gid']).'">'.$row['title'].'</a></li>';
                        //最后打印出数据,由于当前代码的位置是在while的循环体,因此会循环$num条数据
					 ?>
<li class=""><a href="<?php echo Url::log($row['gid']); ?>"><?php echo $row['title']; ?></a></li>
		<?php } ?>
<?php } ?>
<?php
//get thumbs(获取附件图片)
function picthumb($blogid) {
    $db = MySql::getInstance();
    $sql = "SELECT * FROM ".DB_PREFIX."attachment WHERE blogid=".$blogid." AND (`filepath` LIKE '%jpg' OR `filepath` LIKE '%gif' OR `filepath` LIKE '%png') ORDER BY `aid` ASC LIMIT 0,1";
//    die($sql);
	$imgs = $db->query($sql);
    while($row = $db->fetch_array($imgs)){
	        $pict.= ''.BLOG_URL.substr($row['filepath'],3,strlen($row['filepath'])).'';
    }
    return $pict;
}
?>
<?php
//get thumbs(获取图片链接)
function pic_thumb($content){
    //preg_match_all全局匹配content中的图片地址,并存入$img变量
    preg_match_all("|<img[^>]+src=\"([^>\"]+)\"?[^>]*>|is", $content, $img);
    //当图片存在时,获取第一张图片,地址保存在$imgsrc中
    $imgsrc = !empty($img[1]) ? $img[1][0] : '';
	if($imgsrc):
		return $imgsrc;
	endif;
}
?>


二、在head.php引入封装js特效代码:

<script type="text/javascript" src="<?php echo TEMPLATE_URL; ?>js/MSClass.js" language="javascript"></script>

三、在index.php或者log_list.php添加调用参数:

<script type="text/javascript">
function $(id){return document.getElementById(id)};
</script>
					<div id="focusPic">
						<div id="focusLeft"><ul id="focuscontent"><?php echo get_flash_data_img(10); ?></ul></div>
			
						<div id="focusTitle"><ul id="focusMenu"><?php echo get_flash_data_art(10); ?></ul></div>
				<div class="clear"></div>
	</div>
			<script type="text/javascript">
new Marquee(
{
	MSClassID : "focusLeft",
	ContentID : "focuscontent",
	TabID	  : "focusMenu",
	Direction : 0,
	Step	  : 0.3,
	Width	  : 420,
	Height	  : 280,
	Timer	  : 20,
	DelayTime : 3000,
	WaitTime  : 0,
	ScrollStep: 280,
	SwitchType: 0,
	AutoStart : 1,
})
</script>


最后,附加css样式表,在首页css样式表文件中加入如下样式表代码:


#focusPic{width:720px; height:282px; margin:0 auto; clear:both; text-align:center; padding:0px;background-color:#ffffff;border:1px solid #c1c1c1;}
#focusPic ul{margin:0;padding:0;border:0}
#focusPic #focusTitle{width:300px; float:right; font-size:12px; text-align:left;}
#focusPic #focusTitle li{height:28px; line-height:28px; background:url(images/focusTitleBg.gif) left 0 no-repeat; cursor:pointer; font-size:12px; padding-left:20px;overflow:hidden;}
#focusPic #focusMenu li.active{background-position:0 -29px; font-weight:bold;}
#focusPic #focusMenu li.active a{color:#f2f2f2;}
#focusPic #focusLeft{width:420px; height:280px; overflow:hidden; float:left;}
#focusPic #focusLeft #focuscontent li{width:420px;height:280px; overflow:hidden;}


附件下载:
MSClass大小:7.5KB | 来源:本地下载
已经过安全软件检测无毒,请您放心下载。


[green]请将你要显示在幻灯片中的文章首页指定,否则无数据显示![/green]

本文标签:

版权声明:若无特殊注明,本文皆为《Finally》原创,转载请保留文章出处。

本文链接:EMLOG图文轮播幻灯片 - https://pjax.cn/post/129

发表评论

电子邮件地址不会被公开。 必填项已用*标注

允许邮件通知

评论

2条评论
  1. avatar

    lingmerlg Lv.2 uBrowser 7.5 uBrowser 7.5 Windows 7 x64 Edition Windows 7 x64 Edition 回复

    表情

    湖南省长沙市 电信

    1. avatar

      mrxn Lv.6 Internet Explorer 11.0 Internet Explorer 11.0 Windows 7 x64 Edition Windows 7 x64 Edition 回复

      无语... 表情

      黑龙江省鸡西市 联通

      00:00 / 00:00
      顺序播放