Vue增删改查+图片上传+分页

<template>
<div id="app" class="bg">

<h1>规格管理</h1>

<el-divider class="margin"></el-divider>

<el-input
size="small"
class="input"
placeholder="请输入分类名称"
v-model="stan_name"
maxlength="30"
clearable
>
</el-input>
<el-button
type="primary"
icon="el-icon-search"
size="small"
@click="query()"
>查询
</el-button>
<div>

<el-button
type="primary"
icon="el-icon-plus"
class="margin"
size="small"
@click="dialogTableVisible = true"
>新增
</el-button>
</div>

<div>

<el-dialog
title="商品分类"
:visible.sync="dialogTableVisible"
width="60%"
append-to-body
>
<el-row>
<el-col :span="14">
<div class="grid-content bg-purple">
<el-form-item label="上级分类:" style="width: 300px">
<template>
<el-select
v-model="val"
style="width: 300px"
clearable
placeholder="上级分类名称"
>
<el-option
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</template>
</el-form-item>
<div>
<el-form-item label="分类名称:" style="width: 200px">
<el-input
placeholder="分类名称"
style="width: 300px"
v-model="comc_name"
clearable
class="width"
></el-input>
</el-form-item>
</div>
<div class="center">
<el-form-item label="分类描述:" style="width: 200px">
<textarea
name="maosu"
id=""
cols="40"
rows="15"
v-model="comc_desc"
placeholder="分类描述"
></textarea>
</el-form-item>
</div>
</div>
</el-col>
<el-col :span="10">

<el-form-item label="商品图片" style="width: 200px">
<el-upload
action="https://jsonplaceholder.typicode.com/posts/"
list-type="picture-card"
:on-preview="handlePictureCardPreview"
:on-remove="handleRemove"
>
<i class="el-icon-plus"></i>
</el-upload>
<el-dialog :visible.sync="dialogVisible">
<img width="100%" :src="dialogImageUrl" alt="" />
</el-dialog>
</el-form-item>
</el-col>
</el-row>
<div slot="footer" class="dialog-footer">
<el-button @click="dialogTableVisible = false">取 消</el-button>
<el-button type="primary" @click="determine">确 定 </el-button>
</div>
</el-dialog>
</div>

<template>
<el-table
ref="multipleTable"
:data="tableData"
tooltip-effect="dark"
style="width: 100%; "
:header-cell-style="tableHeaderColor"
@selection-change="handleSelectionChange"
>
<el-table-column type="selection" width="55"></el-table-column>
<el-table-column prop="comc_pno" label="商品分类名称" width="">
</el-table-column>
<el-table-column prop="comc_name" label="商品名称" width="">
</el-table-column>
<el-table-column prop="comc_desc" label="商品分类描述" width="">
</el-table-column>
<el-table-column prop="comc_img" label="商品分类图片" width="150">
<template slot-scope="scope">
<el-image
style="width: 100px;height: 100px"
:src="scope.row.comc_img"
></el-image>
</template>
</el-table-column>
<el-table-column prop="comc_lower" label="下架商品数量" width="">
</el-table-column>
<el-table-column prop="comc_upper" label="上架商品数量" width="">
</el-table-column>
<el-table-column fixed="right" label="操作" width="150">
<template slot-scope="scope">
<el-button
@click="Modify(scope.row)"
size="mini"
type="primary"
icon="el-icon-edit"
></el-button>
<el-button
@click="Delete(scope.row)"
size="mini"
type="danger"
icon="el-icon-delete"
></el-button>
</template>
</el-table-column>
</el-table>
</template>

<div class="block">
<el-pagination
v-show="show"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="currentPage"
:page-size="pageSize"
background
:page-sizes="[3, 6, 10, 15, 20]"
layout="total, sizes, prev, pager, next, jumper"
:total="count"
>
</el-pagination>
</div>
</div>
</template>

<script>
export default {
name: "specifications",
data() {
return {
show: true,
// 总条数
count: 1,
// 当前页
currentPage: 1,
// 显示条数
pageSize: 5,
//查询名称
stan_name: "",
//添加分类名称
text: "",
//添加分类描述
maosu: "",
// 图片上传
imageUrl: "",
// 弹出框,
value: [],
options: [
{
value: 1,
label: "黄金糕"
},
{
value: 2,
label: "双皮奶"
},
{
value: 3,
label: "蚵仔煎"
},
{
value: 4,
label: "龙须面"
},
{
value: 5,
label: "北京烤鸭"
}
],
val: "",
dialogTableVisible: false,

  //    批量删除
  disabled: true,
  //    表格假数据
  tableData: [
    {
      comc_no: 2, // 商品分类编号
      comc_name: "香蕉", //商品分类名称
      comc_pno: "1", //商品分类上级编号
      comc_desc: "122324@qq.com", //商品分类描述
      comc_img: "../../assets/logo.png", //商品分类图片
      comc_lower: 10, //下架商品数量
      comc_upper: 20 //上架商品数量
    }
  ],
  multipleSelection: []
};

},
methods: {
//提交信息
submit() {
this.dialogTableVisible = false;
console.log(this.val);
},
// 图片上传
handleAvatarSuccess(res, file) {
console.log("mfoiejfoelfm");
this.imageUrl = URL.createObjectURL(file.raw);
},
beforeAvatarUpload(file) {
const isJPG = file.type === "image/jpeg";
const isLt2M = file.size / 1024 / 1024 < 2;
if (!isJPG) {
this.message.error("上传头像图片只能是 JPG 格式!"); } if (!isLt2M) { this.message.error("上传头像图片大小不能超过 2MB!");
}
return isJPG && isLt2M;
}, //弹出框数据
handleChange(value) {
console.log(value);
},
// 分页获取数据
shuju() {
this.axios .post( "/api/sale/queryComc.do", { page: this.currentPage, limit: this.pageSize }, { // 设置请求头 headers: { "Content-Type": "application/json" } } ) .then(response => { console.log(response); this.tableData = response.data.data; this.count = response.data.count; // console.log(typeof response.data) // this.count = response.data.data // console.log(this.count) }) .catch(err => { console.log(err); }); }, // 每页显示条数 handleSizeChange(val) { this.pageSize = val; this.shuju(); }, // 分页 handleCurrentChange(pag) { console.log(pag); this.currentPage = pag; this.shuju(); }, // 查询 query() { for (var i = 0; i < this.tableData.length; i++) { if (this.tableData[i].comc_name.indexOf(this.stan_name) >= 0) { this.tableDatap.push(this.tableData[i]); } else { this.message("没有数据");
}
}
},
// 修改table header的背景色
tableHeaderColor({ rowIndex }) {
if (rowIndex === 0) {
return "background-color: #90ADE5;color: #fff;font-weight:500;height:60px";
}
},

// 批量删除
batchBelete() {
  for (var i = 0; this.multipleSelection.length; i++) {
    console.log(12334566);
    console.log(this.multipleSelection[i]);

    this.tableData.splice(this.multipleSelection[i], 1);
    this.$message("删除成功");
    this.disabled = true;
  }
},
// 表格复选框
handleSelectionChange(val) {
  this.disabled = false;
  this.multipleSelection = val;
  console.log(val);
},
// 修改
Modify(val) {
  console.log(val);
  this.dialogTableVisible = true;
  // this.options=val
  this.val = val.comc_pno;
  this.text = val.comc_name;
  this.maosu = val.comc_desc;
  this.imageUrl = val.comc_img;
  console.log(this.val);
},
// 删除
Delete(val) {
  this.tableData.splice(val, 1);
  if (this.tableData.length == 0) {
    this.count = 0;
  }
}

},
mounted: function() {
// 请求数据
this.$axios
.post(
"/api/sale/queryComc.do",
{
page: this.currentPage,
pageSize: this.pageSize
},
{
// 设置请求头
headers: {
"Content-Type": "application/json"
}
}
)
.then(response => {
console.log(response.data.data.list);
this.tableData = response.data.data;
this.count = response.data.data.count;
})
.catch(err => {
console.log(err);
});
}
};
</script>

<style scoped>
.block {
margin-top: 20px;
margin-bottom: 20px;
text-align: center;
}
/图片/
.el-upload {
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
}
.avatar-uploader .el-upload {
border: 1px dashed #d92651;
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
}
.avatar-uploader .el-upload:hover {
border-color: #409eff;
}
.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 178px;
height: 178px;
line-height: 178px;
text-align: center;
}
.avatar {
width: 178px;
height: 178px;
display: block;
}
/**/
.center {
height: 200px;
width: 300px;
}
.center input {
margin-top: 20px;
}
.width {
width: 150px;
margin-top: 20px;
margin-bottom: 20px;
}

.bg {
background-color: ghostwhite;
margin: 0;
padding: 10px;
height: 1200px;
}

.input {
width: 200px;
margin-right: 50px;
}

.margin {
margin-top: 20px;
margin-bottom: 20px;
}
</style>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352