Octopus系列之各个页面调用示例
调用首页产品
可选参数如下
New = 1,
Hot = 2,
Best = 3,
Special = 4,
Featured = 5,
Other = 6
#foreach($item in $oct.GetProductstList(${currency},6,$ptype.Best))
<dl class="indexlist">
<dt class="proimg">
<a href="${item.url}" title="">
<img src="${item.images.smallimg}" title="" alt="" />
</a>
</dt>
<dd class="prodName">
<a href="${item.url}" title="">${item.name}</a>
</dd>
<dd class="prodPrice">
<span class="oldPrice">${item.NormalPrice}</span>
<span class="price">${item.SalePrice}</span>
<span class="discount">Save:${item.Saveoff} off</span>
</dd>
</dl>
#end
列表页 调用面包屑导航
<div id="breadcrumb" class="breadcrumbs">
<ul>
#foreach($item in $category.Breadcrumb)
#beforeall
<li class="home"><a title="${Oct_Home}" href="${siteurl}">${Oct_Home}</a><span>/ </span></li>
#each
<li class="">
<a href="${item.url}">${item.name}</a>
#if(${category.ClassLayer}!=1)
<span>/</span>
#end
</li>
#afterall
#if(${category.ClassLayer}!=1)
<li class="">${category.name}</li>
#end
#end
</ul>
</div>
调用全部分类【支持无限级的调用,根据需要自己编写】 下面展示4级分类的调用
<div>
<dl>
#foreach($item in $categorylist)
<dd>
<a href="${item.url}">${item.name}</a>
#foreach($s in $item.SubClass)
#beforeall
<ul>
#each
<li>
<a href="${s.url}">${s.name}</a>
#foreach($o in $s.SubClass)
#beforeall
<ul>
#each
<li>
<a href="${o.url}">${o.name}</a>
#foreach($p in $o.SubClass)
#beforeall
<ul>
#each
<li><a href="${p.url}">${p.name}</a></li>
#afterall
</ul>
#end
</li>
#afterall
</ul>
#end
</li>
#afterall
</ul>
#nodata
#end
</dd>
#end
</dl>
</div>
很长看不懂吗?很简单 自己运行一下
调用产品列表
<div id="gridInner">
#set($count=0)
#foreach($item in $productlist)
#set($count=$count+1)
<div class="plist">
<div class="proimg">
<a href="${item.url}" title="">
<img class="proimgitem" src="${item.images.smallimg}" title="${item.name}" alt="${item.name}" />
<span class="span_box"></span>
</a>
</div>
<div class="description">
<a href="${item.url}" title="${item.name}">
${item.name}
</a>
</div>
<div class="prodesprice">
<span class="retail-price">
<span class="set-currency">${item.NormalPrice}</span>
</span>
<span class="price">${item.SalePrice}</span>
<span class="discount">Save:${item.Saveoff} off</span>
</div>
</div>
#if($count%3==0)
<div class="clear separator"></div>
#end
#end
<div style="clear:both;height:5px"></div>
<div class="default">
${pager}
</div>
</div>
关于分页的样式,已经内置几种样式可以自己定义
调用详情页面包屑【和分页的有点细微差别】
<div id="breadcrumb" class="breadcrumbs">
<ul>
#foreach($item in ${product.category.breadcrumb})
#beforeall
<li class="home"><a title="${Oct_Home}" href="${siteurl}">${Oct_Home}</a><span>/</span></li>
#each
<li class="">
<a href="${item.url}">${item.name}</a>
#if(${product.category.classlayer}!=1)
<span>/</span>
#end
</li>
#afterall
#if(${product.category.classlayer}!=1)
<li class=""><a href="${item.url}">${product.category.name}</a></li>
#end
#end
</ul>
</div>
【通过产品的category对象来调用】
调用产品的多选属性
<div class="box">
#foreach($item in $product.Attributes)
#if($item.type=="attr_radio")
<div class="$item.type">
<input type="hidden" name="attr_${item.name}" value="" />
<b>$item.Name</b>
<div style="clear:both"></div>
#foreach($a in $item.values)
<span class="unchecked" title="$a.value" data-val="$a.value">
$a.value $oct.CheckValue($a.Pricefix) $a.DVPrice
</span>
#end
<div style="clear:both"></div>
</div>
#end
#if($item.type=="attr_dropdown")
<div class="$item.type">
<b>$item.Name</b>
<select name="attr_$item.Name" onchange="CheckInput(this);">
<option value="" selected="selected">${Oct_Please_Select}</option>
#foreach($a in $item.values)
<option value="$a.value">$a.value $oct.CheckValue($a.Pricefix) $a.DVPrice</option>
#end
</select>
<div style="clear:both"></div>
</div>
#end
#if($item.type=="attr_color_radio")
<div class="$item.type">
<input type="hidden" name="attr_${item.name}" value="" />
<b>$item.Name</b>
<div style="clear:both"></div>
#foreach($a in $item.values)
<span class="unchecked" data-val="$a.value">
<img src="${themeurl}images/color/$a.Icon"
title="$a.value $oct.CheckValue($a.Pricefix) $a.DVPrice"
width="32" />
</span>
#end
<div style="clear:both"></div>
</div>
#end
#if($item.type=="attr_text")
<div class="$item.type">
#foreach($a in $item.values)
<b>$item.Name:</b>
<input type="text" name="attr_${item.name}" value="" onchange="CheckInput(this)" />
<br />
#end
<div style="clear:both"></div>
</div>
#end
#end
</div>
这个大家还是自己看吧 【懒得口舌了,想要之后可以私下联系我,如果更新了 我会在上面更新的】
其实之所以这样贴出来是为了大家方便,其实Octopus完全支持自定义的模板开发的 不过你要完全熟悉我的对象实体 才行
调用关联产品
<div class="box">
#foreach($rp in $product.Related)
<a href="$rp.url" title="$rp.name">
<img src="$rp.images.smallimg" width="85" style="border:1px solid #EEEEEE" />
</a>
#end
</div>
调用上一个产品下一个产品
<div class="box" style="font-weight: bold; font-size: 14px; color: #990000;">
<a class="cor990000" href="$product.PreviousUrl"><< ${Oct_Prev}</a>
<a class="cor990000" href="$product.category.URL">${Oct_Listing}</a>
<a class="cor990000" href="$product.NextUrl">${Oct_Next} >></a>
</div>
调用收藏夹
#if(${islogin})
#if(${iswishlist})
<a name="btnAddToWishList" class="litb-btn-small" id="favorite" href="javascript:void(0)"
data-pid="${product.productid}"
data-login="${islogin}"
data-iswishlist="${iswishlist}"
onclick="AddToWish(this)">
<i class="litb-icon-prod-heart litb-icon-prod-heart-active"></i>
${Oct_Favorite}
</a>
#else
<a name="btnAddToWishList" class="litb-btn-small" id="favorite" href="javascript:void(0)"
data-pid="${product.productid}"
data-login="${islogin}"
data-iswishlist="${iswishlist}"
onclick="AddToWish(this)">
<i class="litb-icon-prod-heart"></i>
${Oct_Favorite}
</a>
#end
#else
<a name="btnAddToWishList" class="litb-btn-small" id="favorite" href="javascript:void(0)"
data-login="${islogin}" onclick="AddToWish(this)">
<i class="litb-icon-prod-heart"></i>Favorite
</a>
#end
调用产品放大镜
<div class="zoom-section">
<div class="zoom-small-image">
<a id="zoom1" class="cloud-zoom" href="${product.images.bigimg}"
rel="position:'inside',showTitle: false,adjustX:0,adjustY:0">
<img src="${product.images.middleimg}" />
</a>
</div>
</div>
<div class="zoom-desc">
#foreach($img in $product.images.imagelist)
<a class="cloud-zoom-gallery" title="" href="$img.bigimg" rel="useZoom: 'zoom1', smallImage: '$img.middleimg' ">
<img class="zoom-tiny-image" alt="Thumbnail 0" src="$img.smallimg" />
</a>
#end
</div>
调用随机产品
#foreach($item in $oct.GetRandomProductList(${currency},3))
<dl>
<dt>
<a href="$item.url" title="$item.name">
<img src="$item.images.smallimg" title="$item.name" alt="$item.name" width="189" />
</a>
</dt>
<dd class="prodName">
<a href="$item.url" title="$item.name">$item.name</a>
</dd>
<dd class="prodPrice">
<span class="oldPrice">${item.NormalPrice}</span>
<span class="price">${item.SalePrice}</span>
<span class="discount">Save:${item.Saveoff} off</span>
</dd>
</dl>
#end
调用函数
字符截取
$oct.CutString("${item.ProductID}+${item.name}",45)
$oct.CutUrl(${siteurl})
Octopus系列之各个页面调用示例的更多相关文章
- Octopus系列之各个页面调用示例2
判断登陆的调用 #if(${islogin}) <span> ${Oct_Welcome} or <a href="${siteurl}customer/logout/&q ...
- 利用JavaScriptSOAPClient直接调用webService --完整的前后台配置与调用示例
JavaScriptSoapClient下载地址:https://archive.codeplex.com/?p=javascriptsoapclient JavaScriptSoapClient的D ...
- ADO.NET系列之事务和调用存储过程
ADO.NET系列之Connection对象 ADO.NET系列之Command对象 ADO.NET系列之DataAdapter对象 ADO.NET系列之事务和调用存储过程 前几篇我们介绍了Conne ...
- 股票数据调用示例代码php
<!--?php // +---------------------------------------------------------------------- // | JuhePHP ...
- iframe父子页面调用小结
子页面调用父页面 $('#Id', window.parent.document); //调用父页面元素 window.parent.func1(); //调用父页面方法 (子页面同理,需将js方 ...
- WebService核心文件【server-config.wsdd】详解及调用示例
WebService核心文件[server-config.wsdd]详解及调用示例 作者:Vashon 一.准备工作 导入需要的jar包: 二.配置web.xml 在web工程的web.xml中添加如 ...
- iframe页面调用父窗口JS函数
A页面iframe 页面B, 此时 如果要在B页面调用父页面A的函数 B页面写法 parent.functionName(); 错误1: 解决办法 var js_domain_async = 'bai ...
- JS 的子父级页面调用
window.frames["iframevehquery"].add(); // 父页面调用嵌套子页面的js函数, iframevehquery 为 iframe 的name值, ...
- Octopus系列之如何让前台的js脚本变得灵活重用
Octopus系列如何让前台的js脚本变得灵活,重用 方式1:ajax方式 方式2:form表单方式 面向对象的脚本封装 jQuery的封装 做Web开发的少不了前台Ajax的使用, 返回true:f ...
随机推荐
- git设置hooks 钩子
github是可以设置hooks的,看:在设置webhooks & services,可在Just the push event.是设定向你的服务器发请求,然后再做相应的处理. https:/ ...
- Leetcode: Can I Win
In the "100 game," two players take turns adding, to a running total, any integer from 1.. ...
- C++ 学习笔记(3) —— 內联函数
内联函数的用处: 用空间换取时间,在调用时不用每次都写调用的汇编. 什么时候内联: 比较小的函数:只有两三行 在循环里循环调用的函数 什么时候不内联: 比较大的函数,2.30行的 递归的函数
- POJ - 2183 Bovine Math Geniuses
“模拟“题,运用哈希,不断地按照一定运算规律对一个结果进行计算,如果重复出现就停止并且输出该数.注意到仔细看题,这种题一定要细心! POJ - 2183 Bovine Math Geniuses Ti ...
- Plextor 浦科特M7VC性能
浦科特一出TLC的SSD,立刻就受到了人们的关注,网上铺天盖地的评测.看了评测感觉不错,于是买了一块来用. 自己测试,似乎和网上的结果差异挺大的. 这是我自己测试的结果.(测试平台为:I7-5820K ...
- ruby on rails on windows
这次想系统学会rails,最终目标是将redmine改造成顺手的工具,主要的手段就是开发redmine插件.虽然网上都推荐使用类Unix系统,可手头只有win7系统,就安装了. 难免会遇到这样那样的问 ...
- 嵌入式Linux内核制作【转】
本文转载自:http://blog.csdn.net/coding__madman/article/details/51291316 1. Linux体系结构 从整体上来分,linux可以分为User ...
- WampServer中MySQL中文乱码解决
1.修改mysql的my.ini文件: 在 [client] 下面增加 default-character-set=utf8 在 [mysqld] 下面增加: character_set_server ...
- python 学习笔记十四 jQuery案例详解(进阶篇)
1.选择器和筛选器 案例1 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 【Spring】Spring的定时任务
> 参考的优秀文章 Task Execution and Scheduling > 版本说明 <dependencies> <dependency> <gro ...