2 Star 4 Fork 0

饶一一/电商网站前台项目

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
search.html 18.16 KB
一键复制 编辑 原始数据 按行查看 历史
Srao 提交于 2019-12-14 13:22 . 电商网站前台界面
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7"/>
<title>乐优商城--商品搜索结果页</title>
<link rel="icon" href="assets/img/favicon.ico">
<link href='./css/material.css' rel="stylesheet">
<link href="./css/vuetify.min.css" rel="stylesheet">
<script src="./js/vue/vue.js"></script>
<script src="./js/vue/vuetify.js"></script>
<script src="./js/axios.min.js"></script>
<script src="./js/common.js"></script>
<link rel="stylesheet" type="text/css" href="css/webbase.css"/>
<link rel="stylesheet" type="text/css" href="css/pages-list.css"/>
<link rel="stylesheet" type="text/css" href="css/widget-cartPanelView.css"/>
<style type="text/css">
* {
box-sizing: unset;
}
.btn-arrow, .btn-arrow:visited, .btn-arrow:link, .btn-arrow:active {
width: 46px;
height: 23px;
border: 1px solid #DDD;
background: #FFF;
line-height: 23px;
font-family: "\5b8b\4f53";
text-align: center;
font-size: 16px;
color: #AAA;
text-decoration: none;
out-line: none
}
.btn-arrow:hover {
background-color: #1299ec;
color: whitesmoke;
}
.top-pagination {
display: block;
padding: 3px 15px;
font-size: 11px;
font-weight: 700;
line-height: 18px;
color: #999;
text-shadow: 0 1px 0 rgba(255, 255, 255, .5);
text-transform: uppercase;
float: right;
margin-top: 6px
}
.top-pagination span {
margin-right: 10px;
}
.logo-list li{
padding:8px;
}
.logo-list li:hover{
background-color: #f3f3f3;
}
.type-list a:hover{
color: #1299ec;
}
.skus {
list-style: none;
}
.skus li{
list-style: none;
display: inline-block;
float: left;
margin-left: 2px;
border: 2px solid #f3f3f3;
}
.skus li.selected{
border: 2px solid #dd1144;
}
.skus img{
width: 25px;
height: 25px;
}
</style>
<script type="text/javascript" src="plugins/jquery/jquery.min.js"></script>
</head>
<body >
<div id="searchApp">
<div id="nav-bottom">
<ly-top/>
</div>
<!--list-content-->
<div class="main" >
<div class="py-container">
<div class="bread">
<!--面包屑-->
<ul class="fl sui-breadcrumb">
<li><span>全部结果:</span></li>
<li ><a href="#">手机</a></li>
<li ><span>手机通讯</span></li>
</ul>
<!--已选择过滤项-->
<ul class="tags-choose">
<li class="tag">
品牌:<span style="color: red">apple</span>
<i class="sui-icon icon-tb-close"></i>
</li>
<li class="tag">
内存:<span style="color: red">4G</span>
<i class="sui-icon icon-tb-close"></i>
</li>
</ul>
<div class="clearfix"></div>
</div>
<!--selector-->
<div class="clearfix selector">
<div class="type-wrap" v-for="(filter, index) in filters" v-show="index<5 || show" :key="index" v-if="filter.k != '品牌'">
<div class="fl key">{{filter.k}}</div>
<div class="fl value">
<ul class="type-list">
<li v-for="(option, j) in filter.options" :key="j" @click="selectFilter(filter.k, option)">
<a>{{option.name}}</a>
</li>
</ul>
</div>
<div class="fl ext"></div>
</div>
<div class="type-wrap logo" v-else>
<div class="fl key brand">{{filter.k}}</div>
<div class="value logos">
<ul class="logo-list">
<li v-for="(option, j) in filter.options" :key="j" v-if="option.image" @click="selectFilter(filter.k, option)">
<img :src="option.image" />
</li>
<li style="text-align: center" v-else @click="selectFilter(filter.k, option)">
<a style="line-height: 30px; font-size: 12px" href="#">{{option.name}}</a>
</li>
</ul>
</div>
<div class="fl ext">
<a href="javascript:void(0);" class="sui-btn">多选</a>
</div>
</div>
<div class="type-wrap" style="text-align: center">
<v-btn small flat @click="show=true" v-show="!show">
更多<v-icon>arrow_drop_down</v-icon>
</v-btn>
<v-btn small="" flat @click="show=false" v-show="show">
收起<v-icon>arrow_drop_up</v-icon>
</v-btn>
</div>
</div>
<!--details-->
<div class="details">
<div class="sui-navbar">
<div class="navbar-inner filter">
<ul class="sui-nav">
<li class="active">
<a href="#">综合</a>
</li>
<li>
<a href="#">销量</a>
</li>
<li>
<a href="#">新品</a>
</li>
<li>
<a href="#">评价</a>
</li>
<li>
<a href="#">价格</a>
</li>
</ul>
<div class="top-pagination">
<span><i style="color: #222;">{{total}}+</i> 商品</span>
<span><i style="color: red;">{{search.page}}</i>/{{totalPage}}</span>
<a class="btn-arrow" @click="prev()" href="#" style="display: inline-block">&lt;</a>
<a class="btn-arrow" @click="next()" href="#" style="display: inline-block">&gt;</a>
</div>
</div>
</div>
<div class="goods-list">
<ul class="yui3-g">
<li class="yui3-u-1-5" v-for="(goods, index) in goodsList" :key="index">
<div class="list-wrap">
<div class="p-img">
<a :href="'item/'+ goods.id +'.html'" target="_blank"><img :src="goods.selected.image" height="200"/></a>
<ul class="skus">
<li :class="{selected : goods.selected.id==sku.id}" v-for="(sku, j) in goods.skus" @mouseOver="goods.selected=sku">
<img :src="sku.image">
</li>
</ul>
</div>
<div class="clearfix"></div>
<div class="price">
<strong>
<em>¥</em>
<i>{{ly.formatPrice(goods.selected.price)}}</i>
</strong>
</div>
<div class="attr">
<em>{{goods.selected.title.length>20 ? goods.selected.title.substring(0, 20) : goods.selected.title}}</em>
</div>
<div class="cu">
<em>{{goods.subTitle.length>15 ? goods.subTitle.substring(0, 15) : goods.subTitle}}</em>
</div>
<div class="commit">
<i class="command">已有2000人评价</i>
</div>
<div class="operate">
<a href="success-cart.html" target="_blank" class="sui-btn btn-bordered btn-danger">加入购物车</a>
<a href="javascript:void(0);" class="sui-btn btn-bordered">对比</a>
<a href="javascript:void(0);" class="sui-btn btn-bordered">关注</a>
</div>
</div>
</li>
</ul>
</div>
<div class="fr">
<div class="sui-pagination pagination-large">
<ul>
<li class="prev" :class="{disabled : search.page==1}" @click="prev()">
<a href="#">«上一页</a>
</li>
<li :class="{active : search.page==index(i)}" v-for="i in Math.min(5, totalPage)" @click="search.page=index(i)">
<a href="#">{{index(i)}}</a>
</li>
<li class="dotted"><span>...</span></li>
<li class="next" :class="{disabled : search.page==totalPage}" @click="next()">
<a href="#">下一页»</a>
</li>
</ul>
<div><span>共10页&nbsp;</span><span>
到第
<input type="text" class="page-num">
<button class="page-confirm" onclick="alert(1)">确定</button></span></div>
</div>
</div>
</div>
<!--hotsale-->
<div class="clearfix hot-sale">
<h4 class="title">热卖商品</h4>
<div class="hot-list">
<ul class="yui3-g">
<li class="yui3-u-1-4">
<div class="list-wrap">
<div class="p-img">
<img src="img/like_01.png"/>
</div>
<div class="attr">
<em>Apple苹果iPhone 6s (A1699)</em>
</div>
<div class="price">
<strong>
<em>¥</em>
<i>4088.00</i>
</strong>
</div>
<div class="commit">
<i class="command">已有700人评价</i>
</div>
</div>
</li>
<li class="yui3-u-1-4">
<div class="list-wrap">
<div class="p-img">
<img src="img/like_03.png"/>
</div>
<div class="attr">
<em>金属A面,360°翻转,APP下单省300!</em>
</div>
<div class="price">
<strong>
<em>¥</em>
<i>4088.00</i>
</strong>
</div>
<div class="commit">
<i class="command">已有700人评价</i>
</div>
</div>
</li>
<li class="yui3-u-1-4">
<div class="list-wrap">
<div class="p-img">
<img src="img/like_04.png"/>
</div>
<div class="attr">
<em>256SSD商务大咖,完爆职场,APP下单立减200</em>
</div>
<div class="price">
<strong>
<em>¥</em>
<i>4068.00</i>
</strong>
</div>
<div class="commit">
<i class="command">已有20人评价</i>
</div>
</div>
</li>
<li class="yui3-u-1-4">
<div class="list-wrap">
<div class="p-img">
<img src="img/like_02.png"/>
</div>
<div class="attr">
<em>Apple苹果iPhone 6s (A1699)</em>
</div>
<div class="price">
<strong>
<em>¥</em>
<i>4088.00</i>
</strong>
</div>
<div class="commit">
<i class="command">已有700人评价</i>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>
</div>
</div>
<script type="text/javascript">
var vm = new Vue({
el: "#searchApp",
data: {
ly,
search: {
key: "",
page: 1,
filter: {}
},
goodsList: [],
totalPage: 1,
total: 0,
filters: [],
show: false
},
created(){
if(!location.search){
return;
}
const search = ly.parse(location.search.substring(1));
search.page = parseInt(search.page) || 1;
search.filter = search.filter || {};
this.search = search;
this.loadData();
},
watch:{
search:{
deep: true,
handler(newVal, oldVal){
if (!oldVal || !oldVal.key){
return;
}
window.location = "http://www.leyou.com/search.html?" + ly.stringify(this.search);
}
}
},
methods: {
loadData(){
ly.http.post("/search/page", this.search).then(({data})=>{
data.items.forEach(goods => {
goods.skus = JSON.parse(goods.skus);
goods.selected = goods.skus[0];
});
this.totalPage = data.totalPage;
this.total = data.total;
this.filters.push({
k: "分类",
options: data.categories
});
this.filters.push({
k: "品牌",
options: data.brands
});
data.specs.forEach(spec=>{
spec.options = spec.options.map(o=>({name: o}));
this.filters.push(spec);
});
this.goodsList = data.items;
})
},
index(i){
if (this.search.page <= 3 || this.totalPage <= 5){
return i;
} else if(this.search.page >= this.totalPage-2){
return this.totalPage-5+i;
}else {
return this.search.page - 3 + i;
}
},
prev(){
if (this.search.page > 1){
this.search.page--;
}
},
next(){
if (this.search.page < this.totalPage){
this.search.page++;
}
},
selectFilter(k, option){
let obj = {};
Object.assign(obj, this.search);
if (k == '分类' || k == '品牌'){
obj.filter[k] = option.id;
}else {
obj.filter[k] = option.name;
}
this.search = obj;
}
},
components:{
lyTop: () => import("./js/pages/top.js")
}
});
</script>
<!-- 底部栏位 -->
<!--页面底部,由js动态加载-->
<div class="clearfix footer"></div>
<script type="text/javascript">$(".footer").load("foot.html");</script>
<!--页面底部END-->
</body >
<!--购物车单元格 模板-->
<script type="text/template" id="tbar-cart-item-template">
<div class="tbar-cart-item">
<div class="jtc-item-promo">
<em class="promo-tag promo-mz">满赠<i class="arrow"></i></em>
<div class="promo-text">已购满600元您可领赠品</div>
</div>
<div class="jtc-item-goods">
<span class="p-img"><a href="#" target="_blank"><img src="{2}" alt="{1}" height="50" width="50"/></a></span>
<div class="p-name">
<a href="#">{1}</a>
</div>
<div class="p-price"><strong>¥{3}</strong>×{4}</div>
<a href="#none" class="p-del J-del">删除</a>
</div>
</div>
</script>
<!--侧栏面板结束-->
<script type="text/javascript" src="js/plugins/jquery/jquery.min.js"></script>
<script type="text/javascript">
$(function () {
$("#service").hover(function () {
$(".service").show();
}, function () {
$(".service").hide();
});
$("#shopcar").hover(function () {
$("#shopcarlist").show();
}, function () {
$("#shopcarlist").hide();
});
})
</script>
<script type="text/javascript" src="js/model/cartModel.js"></script>
<script type="text/javascript" src="js/czFunction.js"></script>
<script type="text/javascript" src="js/plugins/jquery.easing/jquery.easing.min.js"></script>
<script type="text/javascript" src="js/plugins/sui/sui.min.js"></script>
<script type="text/javascript" src="js/widget/cartPanelView.js"></script>
</html>
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/rao11/business_front_desk.git
git@gitee.com:rao11/business_front_desk.git
rao11
business_front_desk
电商网站前台项目
master

搜索帮助