Vue增刪改查+圖片上傳+分頁

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

<h1>規(guī)格管理</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="下架商品數(shù)量" width="">
</el-table-column>
<el-table-column prop="comc_upper" label="上架商品數(shù)量" 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,
// 總條數(shù)
count: 1,
// 當前頁
currentPage: 1,
// 顯示條數(shù)
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,
  //    表格假數(shù)據
  tableData: [
    {
      comc_no: 2, // 商品分類編號
      comc_name: "香蕉", //商品分類名稱
      comc_pno: "1", //商品分類上級編號
      comc_desc: "122324@qq.com", //商品分類描述
      comc_img: "../../assets/logo.png", //商品分類圖片
      comc_lower: 10, //下架商品數(shù)量
      comc_upper: 20 //上架商品數(shù)量
    }
  ],
  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;
}, //彈出框數(shù)據
handleChange(value) {
console.log(value);
},
// 分頁獲取數(shù)據
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); }); }, // 每頁顯示條數(shù) 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("沒有數(shù)據");
}
}
},
// 修改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() {
// 請求數(shù)據
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>

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末檩咱,一起剝皮案震驚了整個濱河市熬尺,隨后出現(xiàn)的幾起案子稻据,更是在濱河造成了極大的恐慌锭沟,老刑警劉巖嚼摩,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異冲九,居然都是意外死亡汗销,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門梢为,熙熙樓的掌柜王于貴愁眉苦臉地迎上來渐行,“玉大人轰坊,你說我怎么就攤上這事∷钣。” “怎么了肴沫?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蕴忆。 經常有香客問我樊零,道長,這世上最難降的妖魔是什么孽文? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任驻襟,我火速辦了婚禮,結果婚禮上芋哭,老公的妹妹穿的比我還像新娘沉衣。我一直安慰自己,他們只是感情好减牺,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布豌习。 她就那樣靜靜地躺著,像睡著了一般拔疚。 火紅的嫁衣襯著肌膚如雪肥隆。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天稚失,我揣著相機與錄音栋艳,去河邊找鬼。 笑死句各,一個胖子當著我的面吹牛吸占,可吹牛的內容都是我干的。 我是一名探鬼主播凿宾,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼矾屯,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了初厚?” 一聲冷哼從身側響起件蚕,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎产禾,沒想到半個月后排作,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡下愈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年纽绍,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片势似。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡拌夏,死狀恐怖僧著,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情障簿,我是刑警寧澤盹愚,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站站故,受9級特大地震影響皆怕,放射性物質發(fā)生泄漏。R本人自食惡果不足惜西篓,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一愈腾、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧岂津,春花似錦虱黄、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至粱甫,卻和暖如春泳叠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背茶宵。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工危纫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人节预。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓叶摄,卻偏偏與公主長得像,于是被迫代替她去往敵國和親安拟。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354