Browse Source

封装开关组件、表格、输入框、单选框增加属性

master
zq 8 months ago
parent
commit
49ed7dbdd1
  1. 35
      src/components/GuipDialog.vue
  2. 13
      src/components/GuipInput.vue
  3. 4
      src/components/GuipRadio.vue
  4. 101
      src/components/GuipSwitch.vue
  5. 126
      src/components/GuipTable.vue
  6. 46
      src/style/theme/common.scss
  7. 816
      src/views/elementGroups.vue

35
src/components/GuipDialog.vue

@ -6,18 +6,19 @@
:show-close="showCloseButton" :show-close="showCloseButton"
:before-close="handleClose" :before-close="handleClose"
> >
<!-- 自定义内容 --> <!-- 自定义内容 -->
<slot></slot> <slot></slot>
<!-- 底部按钮 -->
<!-- 底部按钮 --> <span slot="footer" class="dialog-footer flex" style="justify-content: space-between;">
<span slot="footer" class="dialog-footer flex"> <GuipButton v-if="showCancelButton" @click="handleCancel" type="mild" >{{ cancelText }}</GuipButton>
<el-button v-if="showCancelButton" @click="handleCancel">{{ cancelText }}</el-button> <GuipButton type="primary" @click="handleConfirm">{{ confirmText }}</GuipButton>
<el-button type="primary" @click="handleConfirm">{{ confirmText }}</el-button> </span>
</span>
</el-dialog> </el-dialog>
</template> </template>
<script> <script>
import GuipButton from '@/components/GuipButton.vue';
export default { export default {
name: 'CustomDialog', name: 'CustomDialog',
props: { props: {
@ -34,7 +35,7 @@
// //
width: { width: {
type: String, type: String,
default: '30%', default: '599px',
}, },
// //
showCloseButton: { showCloseButton: {
@ -57,6 +58,9 @@
default: '确定', default: '确定',
}, },
}, },
components:{
GuipButton
},
computed: { computed: {
dialogShow: { dialogShow: {
get() { get() {
@ -107,8 +111,15 @@
}; };
</script> </script>
<style scoped> <style scoped lang="scss">
.dialog-footer { .el-dialog{
text-align: right; /* width: 599px; */
// min-height: 344px;
// .el-dialog__header{
// padding: 32px 32px 12px;
// }
// .el-dialog__body{
// padding: 0 32px 32px;
// }
} }
</style> </style>

13
src/components/GuipInput.vue

@ -1,6 +1,6 @@
<template> <template>
<el-form-item <el-form-item
:style="{...style,height:height,...styleObject}" :style="{height:height,...styleObject}"
:class="[{'column':column},{'w510':addClass=='w510'},{'w388':addClass=='w388'},'form-item']" :class="[{'column':column},{'w510':addClass=='w510'},{'w388':addClass=='w388'},'form-item']"
:label="label" :prop="prop" :rules="rules"> :label="label" :prop="prop" :rules="rules">
<p v-if="desc" class="desc_right">{{ desc }}</p> <p v-if="desc" class="desc_right">{{ desc }}</p>
@ -37,6 +37,8 @@
<!-- <i slot="suffix" v-if="empty" class="el-icon-close" @click="handleClear">h</i> --> <!-- <i slot="suffix" v-if="empty" class="el-icon-close" @click="handleClear">h</i> -->
<!-- <el-button slot="append" v-if="hasBtn" type="primary" @click="$emit('enter',value)">搜索</el-button> --> <!-- <el-button slot="append" v-if="hasBtn" type="primary" @click="$emit('enter',value)">搜索</el-button> -->
</el-input> </el-input>
<!-- 单位 -->
<span class="unit" v-if="unit">{{ unit }}</span>
</el-form-item> </el-form-item>
</template> </template>
@ -46,7 +48,7 @@
name: 'GuipInput', name: 'GuipInput',
props:['styleObject','disabled','defaultValue','placeholder', props:['styleObject','disabled','defaultValue','placeholder',
'maxlength','minLength','clear','width','height','showWordLimit', 'maxlength','minLength','clear','width','height','showWordLimit',
'label','type','prop','rules','column','addClass','desc'], 'label','type','prop','rules','column','addClass','desc','unit'],
data() { data() {
return { return {
value: '', value: '',
@ -131,4 +133,11 @@
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.unit {
position: absolute;
right: 12px; /* 根据需要调整位置 */
top: 50%;
transform: translateY(-50%);
pointer-events: none; /* 防止单位文本影响输入框的点击事件 */
}
</style> </style>

4
src/components/GuipRadio.vue

@ -12,7 +12,9 @@
:label="option.value" :label="option.value"
:disabled="option.disabled" :disabled="option.disabled"
> >
{{ option.label }} <!-- 默认展示和选中显示 不同文案 -->
{{ selectedValue === option.value ? option.selectedLabel : option.label }}
<!-- 自定义 选中图标 -->
<!-- <template #label> <!-- <template #label>
<span><img src="../assets/radio_checked.svg" alt="custom icon" style="width: 16px; height: 16px;"> {{ text }}</span> <span><img src="../assets/radio_checked.svg" alt="custom icon" style="width: 16px; height: 16px;"> {{ text }}</span>
</template> --> </template> -->

101
src/components/GuipSwitch.vue

@ -0,0 +1,101 @@
<template>
<div class="flex switchWrap">
<span class="switchDesc" v-if="activeText || inactiveText">{{ internalValue ? activeText : inactiveText }}</span>
<el-switch
v-model="internalValue"
:active-color="activeColor"
:inactive-color="inactiveColor"
:disabled="disabled || loading"
@change="handleChange">
<!-- 自定义开启时的图标 -->
<template #active-icon>
</template>
<!-- 自定义关闭时的图标 -->
<template #inactive-icon>
</template>
</el-switch>
</div>
</template>
<!-- 他这个描述文案不太符合当前使用暂且不用 -->
<!-- :active-text="activeText"
:inactive-text="inactiveText" -->
<script>
export default {
name: 'CustomSwitch',
props: {
activeText: {
type: String,
default: '',
},
inactiveText: {
type: String,
default: '',
},
modelValue: {
type: Boolean,
default: false,
},
activeColor: {
type: String,
default: '#00C261',
},
inactiveColor: {
type: String,
default: '#BABDC2',
},
disabled: {
type: Boolean,
default: false,
},
},
emits: ['update:modelValue', 'change'],
data() {
return {
internalValue: this.modelValue,
loading: false, //
};
},
watch: {
modelValue(newVal) {
this.internalValue = newVal;
},
},
methods: {
// switch
async handleChange(value) {
this.loading = true;
try {
//
await new Promise((resolve) => setTimeout(resolve, 1000));
this.internalValue = value;
this.$emit('update:modelValue', value);
this.$emit('change', value);
} catch (error) {
console.error('操作失败:', error);
} finally {
this.loading = false;
}
},
},
components: {
},
};
</script>
<style scoped>
.switchWrap{
align-items: center;
}
.switchDesc{
font-size: 12px;
font-weight: normal;
line-height: 13px;
letter-spacing: 0.08em;
font-variation-settings: "opsz" auto;
/* text/text_3 */
color: #626573;
display: inline-block;
margin-right: 15px;
}
</style>

126
src/components/GuipTable.vue

@ -1,52 +1,86 @@
<template> <template>
<el-table <el-table ref="guiptable" :data="tableData" height="250" :border="border" @selection-change="handleSelectionChange"
ref="guiptable" :style="{ width: width ? width : '100%' }">
:data="tableData" <!-- 多选 -->
height="250" <template v-if="multiple">
:border="border" <el-table-column type="selection" width="55">
@selection-change="handleSelectionChange" </el-table-column>
:style="{width: width? width :'100%'}"> </template>
<!-- 多选 -->
<template v-if="multiple">
<el-table-column
type="selection"
width="55">
</el-table-column>
</template>
<!-- 自定义header --> <!-- 自定义header -->
<template v-if="autoColumn"> <template v-if="autoColumn">
<slot name="header"></slot> <slot name="header"></slot>
</template> </template>
<!-- 通过json数据遍历渲染 --> <!-- 通过json数据遍历渲染 -->
<template v-if="columns"> <template v-if="columns">
<el-table-column <el-table-column v-for="column in columns" :key="column.prop" :prop="column.prop" :label="column.label"
v-for="column in columns" :width="column.width">
:key="column.prop" <template #default="{ row }" v-if="column.popover">
:prop="column.prop" <el-popover :visible="row[`popoverVisible_${column.prop}`]" class="tablePopover" placement="top" trigger="click">
:label="column.label" <!-- 自定义内容插槽 -->
:width="column.width"> <slot :name="`popover-content-${column.prop}`" :row="row" :column="column">
</el-table-column> <div>
</template> <p>默认内容{{ `popoverVisible_${column.prop}` }}</p>
<el-input v-model="row[`edit_${column.prop}`]" :placeholder="`请输入${column.label}`" />
</div>
</slot>
<!-- 确定和取消按钮 -->
<div class="flex" style="text-align: right; margin-top: 32px;justify-content: flex-end;">
<GuipButton size="medium" @click="handleCancel(row, column.prop)">取消</GuipButton>
<GuipButton type="primary" @click="handleConfirm(row, column.prop)" size="medium">确定</GuipButton>
</div>
<!-- 单元格内容 -->
<template #reference>
<span style="cursor: pointer">{{ row[column.prop] }}</span>
</template>
</el-popover>
</template>
</el-table-column>
</template>
</el-table> </el-table>
</template> </template>
<script> <script>
export default { import GuipButton from '@/components/GuipButton.vue';
name: 'GuipTextarea',
props:['tableData','width','autoColumn','columns','border','multiple'], export default {
data() { name: 'GuipTextarea',
return { props: ['tableData', 'width', 'autoColumn', 'columns', 'border', 'multiple'],
data() {
return {
}
},
methods:{
handleSelectionChange(row){
//
console.log(row,'======');
this.$emit('selectChange',row)
}
} }
} },
</script> components: {
GuipButton
},
mounted(){
},
methods: {
handleSelectionChange(row) {
//
console.log(row, '======');
this.$emit('selectChange', row)
},
//
handleConfirm(row, prop) {
//
row[prop] = row[`edit_${prop}`];
row[`popoverVisible_${prop}`] = false; //
this.$emit('confirm', row, prop); //
},
//
handleCancel(row, prop) {
//
row[`edit_${prop}`] = row[prop];
row[`popoverVisible_${prop}`] = false; //
this.$emit('cancel', row, prop); //
},
}
}
</script>
<style scoped>
</style>

46
src/style/theme/common.scss

@ -2,6 +2,10 @@
body{ body{
font-family: Microsoft YaHei UI; font-family: Microsoft YaHei UI;
font-size: 14px; font-size: 14px;
p{
margin: 0;
padding: 0;
}
} }
/* button==== start */ /* button==== start */
@ -307,12 +311,54 @@ body{
// table end // table end
// dialog--start // dialog--start
.el-dialog{
min-height: 344px;
max-height: 550px;
border-radius: 4px;
background: #FFFFFF;
box-shadow: 0px 4px 16px 0px rgba(0, 0, 0, 0.16);
display: flex;
flex-direction: column;
.el-dialog__header{
font-size: 20px;
font-weight: bold;
line-height: 26px;
letter-spacing: 0.08em;
color: #1F2026;
padding: 32px 32px 12px;
}
.el-dialog__body{
padding: 0 32px 32px;
flex: 1;
}
}
.el-dialog__footer{ .el-dialog__footer{
display: flex; display: flex;
justify-content: center; justify-content: center;
padding: 0 32px 32px !important;
.dialog-footer{
width: 100%;
justify-content: space-between;
}
button{
width: 247px;
height: 44px;
}
} }
// dialog--end // dialog--end
// switch --start
// .el-switch__core{
// background-color: #00C261;
// }
// .el-switch.is-checked .el-switch__core{
// background-color: #BABDC2;
// }
// switch --end
.el-popover{
padding: 32px;
}
.flex{ .flex{
display: flex; display: flex;
align-items: center; align-items: center;

816
src/views/elementGroups.vue

@ -1,230 +1,216 @@
<template> <template>
<div class="elementWrap"> <div class="elementWrap">
<!-- ele-item 为类名的这种div label h3 仅在此页面进行布局使用复制时无需复制此元素 --> <!-- ele-item 为类名的这种div label h3 仅在此页面进行布局使用复制时无需复制此元素 -->
<el-form :model="form" :rules="rules" class="el-row demo-ruleForm" ref="formRef"> <el-form :model="form" :rules="rules" class="el-row demo-ruleForm" ref="formRef">
<div class="ele-item"> <div class="ele-item">
<label for="">单选框</label> <label for="">单选框</label>
<GuipRadio <GuipRadio v-model="form.language" :options="languageOptions" label="选择语言" prop="language"
v-model="form.language" @change="radioChange" :rules="rules.language" />
:options="languageOptions" </div>
label="选择语言" <div class="ele-item">
prop="language" <label for="">下拉框</label>
@change="radioChange" <GuipSelect width="600px" v-model="form.card" label="卡片" prop="card" :options="options"
:rules="rules.language"/> defaultValue="选项1" />
</div> </div>
<div class="ele-item"> <div >
<label for="">下拉框</label> <h3 for="">表格(表头自定义自定义渲染固定列)</h3>
<GuipSelect width="600px" <GuipButton type="primary" @click="toggleAllSelection">全选按钮</GuipButton>
v-model="form.card" label="卡片" prop="card"
:options="options" defaultValue="选项1"/> <GuipTable :tableData="tableData" ref="multipleTable" @selectChange="handleSelectionChange"
</div> :multiple="true" autoColumn="true" width="900px">
<div class="ele-item"> <template slot="header">
<label for="">表格</label> <el-table-column fixed prop="date" label="日期" width="180"></el-table-column>
<GuipButton type="primary" @click="toggleAllSelection">全选按钮</GuipButton> <el-table-column prop="name" label="姓名" width="150"></el-table-column>
<el-table-column prop="name1" label="姓名" width="150"></el-table-column>
<GuipTable :tableData="tableData" <el-table-column prop="name2" label="姓名" width="150"></el-table-column>
ref="multipleTable" <el-table-column prop="name3" label="姓名" width="150"></el-table-column>
@selectChange="handleSelectionChange" <el-table-column prop="name4" label="姓名" width="150"></el-table-column>
:multiple="true" <el-table-column prop="name5" label="姓名" width="150"></el-table-column>
autoColumn="true" width="900px"> <el-table-column prop="name6" label="姓名" width="150"></el-table-column>
<template slot="header"> <el-table-column prop="name7" label="姓名" width="150"></el-table-column>
<el-table-column prop="date" label="日期" width="180"></el-table-column> <el-table-column prop="name8" label="姓名" width="150"></el-table-column>
<el-table-column prop="name" label="姓名" width="150"></el-table-column> <el-table-column prop="name9" label="姓名" width="150"></el-table-column>
<el-table-column prop="price" label="价格" width="150"> <el-table-column prop="name11" label="姓名" width="150"></el-table-column>
<!-- <template slot-scope="scope"> <el-table-column prop="name12" label="姓名" width="150"></el-table-column>
<el-table-column prop="price" label="价格" width="150">
<!-- <template slot-scope="scope">
<span @click="handlePriceClick(scope.row)">{{ scope.row.price }}</span> <span @click="handlePriceClick(scope.row)">{{ scope.row.price }}</span>
</template> --> </template> -->
<!-- 气泡弹出框 后期样式自定义--> <!-- 气泡弹出框 后期样式自定义-->
<template slot-scope="scope"> <!-- <template slot-scope="scope">
<el-popover trigger="click" placement="top"> <el-popover trigger="click" placement="top">
<!-- <p>姓名: {{ scope.row.name }}</p> <input type="text">
<p>住址: {{ scope.row.address }}</p> --> <div slot="reference" class="name-wrapper">
<input type="text"> <el-tag size="medium">{{ scope.row.price }}</el-tag>
<div slot="reference" class="name-wrapper"> </div>
<el-tag size="medium">{{ scope.row.price }}</el-tag> </el-popover>
</div> </template> -->
</el-popover> </el-table-column>
</template> <el-table-column prop="address" label="地址" width="200"> </el-table-column>
</el-table-column> <el-table-column prop="address1" label="地址测试"></el-table-column>
<el-table-column prop="address" label="地址"> </el-table-column> <el-table-column prop="price2" label="价格" width="300">
<el-table-column prop="address1" label="地址测试"></el-table-column> <!-- 自定义渲染内容 -->
<el-table-column prop="price" label="价格"> <template slot-scope="scope">
<!-- 自定义渲染内容 --> <GuipSelect width="200px" @change="changeSelect(scope.row)" v-model="form.card"
<template slot-scope="scope"> prop="card" :options="options" defaultValue="选项1" />
<GuipSelect </template>
width="200px" </el-table-column>
@change="changeSelect(scope.row)" <el-table-column fixed="right" label="操作" width="100">
v-model="form.card" prop="card" <template slot-scope="scope">
:options="options" defaultValue="选项1"/> <div class="flex">
<el-button @click="handleClick(scope.row)" type="text">查看</el-button>
<el-button type="text">编辑</el-button>
</div>
</template>
</el-table-column>
</template> </template>
</el-table-column> </GuipTable>
<el-table-column </div>
fixed="right"
label="操作" <div >
width="100"> <h3 for="">表格(带气泡框),内容自定义</h3>
<template slot-scope="scope"> <GuipTable :tableData="tableData" :key="random()" ref="multipleTable" @selectChange="handleSelectionChange" :multiple="true"
<div class="flex"> autoColumn="true" width="900px" :columns="columns" @confirm="onConfirm"
<el-button @click="handleClick(scope.row)" type="text">查看</el-button> @cancel="onCancel">
<el-button type="text">编辑</el-button> <!-- 自定义姓名列的气泡框内容 -->
<template #popover-content-name="{ row, column }">
<div>
<GuipInput ref="GuipInput" width="252px" v-model="row[`edit_${column.prop}`]" label="排序" :prop="column.label"
placeholder="这是" />
</div> </div>
</template> </template>
</el-table-column> <template #popover-content-age="{ row, column }">
</template> <GuipInput ref="GuipInput" width="252px" v-model="row[`edit_${column.prop}`]" label="年龄" :prop="column.label"
</GuipTable> placeholder="这是" unit="岁" >
</div> </GuipInput>
<div class="ele-item"> </template>
<label for="">文本域</label> <!-- 自定义地址列的气泡框内容 -->
<GuipTextarea disabled :styleObject="styleObject"/> <template #popover-content-address="{ row, column }">
</div> <div>
<p>自定义内容{{ column.label }}</p>
<el-select v-model="row[`edit_${column.prop}`]" placeholder="请选择">
<el-option label="北京市" value="北京市" />
<el-option label="上海市" value="上海市" />
<el-option label="广州市" value="广州市" />
</el-select>
</div>
</template>
</GuipTable>
</div>
<div class="ele-item">
<label for="">文本域</label>
<GuipTextarea disabled :styleObject="styleObject" />
</div>
<div class="ele-item"> <div class="ele-item">
<label for="">输入框</label> <label for="">输入框</label>
<GuipInput <GuipInput ref="GuipInput" width="200px" height="30px" disabled placeholder="这是自定义默认提示语" />
ref="GuipInput"
width="200px"
height="30px"
disabled
placeholder="这是自定义默认提示语"/>
<div style="width: 20px;height: 10px;"></div>
<GuipInput
ref="GuipInput"
:styleObject="styleObject1"
defaultValue="爱吃麻辣烫"
:maxlength="100"
@change="handleInput"
@blur="handleInput"
@input="handleInput"
@focus="handleInput"
placeholder="这是自定义默认提示语"/>
<div style="width: 20px;height: 10px;"></div>
<GuipInput
:defaultValue="defaultValue"
@clear="handleClear"
width="400px"
>
<span slot="prependshow">http:</span>
<img slot="prefix" src="../assets/radio_checked.svg" alt="">
<!-- 输入框后面小图标 -事件自定义 -->
<i slot="suffix" class="el-icon-close" @click="handleClear"></i>
<!-- <img slot="suffix" src="../assets/radio_nochecked.svg" alt="" @click="handleClear"> -->
<!-- 这个 appendshow 宽度 居中方式 自定义添加类名修改-->
<!-- <GuipButton slot="appendshow" size="mini">默认按钮</GuipButton> -->
<!-- 这个 appendshow 宽度 居中方式 自定义添加类名修改-->
<span slot="appendshow" >.checkcopy.com</span>
</GuipInput>
<!-- <el-input placeholder="oieuwroieuwi" style="width:400px;height:60px"></el-input> -->
</div>
<div class="ele-item">
<label for="">单选框</label>
<el-radio v-model="radio1" :label="1">选项一</el-radio>
<el-radio v-model="radio1" :label="2">选项二</el-radio>
</div>
<div class="ele-item">
<label for="">单选框组</label>
<el-radio-group v-model="radio" @input="radioChange">
<el-radio :label="3">备选项</el-radio>
<el-radio :label="6">备选项</el-radio>
<el-radio :label="9">备选项</el-radio>
</el-radio-group>
</div>
<div class="ele-item">
<label for="">常规按钮</label>
<GuipButton >默认按钮</GuipButton>
<GuipButton type="mild" size="medium">轻度按钮</GuipButton>
<GuipButton type="primary">按钮</GuipButton>
<GuipButton type="reverseMild">按钮</GuipButton>
<GuipButton type="primary" loading>按钮</GuipButton>
<GuipButton type="success" :plain="plain">按钮</GuipButton>
<GuipButton type="info" :plain="plain">按钮</GuipButton>
<GuipButton type="warning" :plain="plain">按钮</GuipButton>
<GuipButton type="danger" :plain="plain">按钮</GuipButton>
</div>
<div class="ele-item">
<label for="">禁用按钮</label>
<GuipButton disabled >默认按钮</GuipButton>
<GuipButton type="mild" disabled size="medium">轻度按钮</GuipButton>
<GuipButton type="reverseMild" disabled>按钮</GuipButton>
<GuipButton type="primary" size="medium" disabled>按钮</GuipButton>
<GuipButton type="success" disabled>按钮</GuipButton>
<GuipButton type="info" disabled>按钮</GuipButton>
<GuipButton type="warning" disabled>按钮</GuipButton>
<GuipButton type="danger" disabled>按钮</GuipButton>
</div>
<div class="ele-item">
<label for="">三种尺寸按钮</label>
<GuipButton type="primary" >默认按钮</GuipButton>
<GuipButton type="primary" size="medium">中等按钮</GuipButton>
<GuipButton type="primary" size="small">小的按钮</GuipButton>
<GuipButton type="primary" size="mini">迷你按钮</GuipButton>
</div>
<div class="ele-item">
<label for="">自定义宽高按钮</label>
<GuipButton type="primary" :btnstyle="btnstyleObj">超长啊扭测试长的长的</GuipButton>
<GuipButton type="primary" :btnstyle="btnstyleObj1">随便写的</GuipButton>
</div>
<div class="ele-item">
<!-- <label for="">表单校验:</label> -->
<!-- <el-form :model="form" :rules="rules" ref="myForm">
<el-form-item label="用户名" prop="username">
<el-input v-model="form.username"></el-input>
</el-form-item>
<div style="display: flex;">
<el-button type="primary" @click="submitForm">提交</el-button>
<el-button @click="triggerError">触发错误</el-button>
</div>
</el-form> -->
</div>
<div style="width: 600px;"> <div style="width: 20px;height: 10px;"></div>
<h3>表单左右布局直接使用封装好的input</h3>
<!-- 表单左右布局 -->
<GuipInput
ref="GuipInput"
addClass="w510"
v-model="form.username" label="Username" prop="username" :rules="usernameRules"
placeholder="这是自定义默认提11示语"/>
</div>
<div style="width: 800px;height: 150px;"> <GuipInput ref="GuipInput" :styleObject="styleObject1" defaultValue="爱吃麻辣烫" :maxlength="100"
<h3>表单上下布局 (宽度 510 388 用的最多 已有这2种宽度类名设置)</h3> @change="handleInput" @blur="handleInput" @input="handleInput" @focus="handleInput"
<GuipInput placeholder="这是自定义默认提示语" />
ref="GuipInput"
column="column"
addClass="w510"
label="age"
desc="这是是右侧文案"
v-model="form.age" prop="age"
placeholder="这是自定义默认提示语"/>
</div>
<div style="width: 600px;height: 150px;"> <div style="width: 20px;height: 10px;"></div>
<h3>获取手机验证码(布局也可更改使用插槽自定义展示内容)</h3>
<GuipFormItem <GuipInput :defaultValue="defaultValue" @clear="handleClear" width="400px">
column="column" <span slot="prependshow">http:</span>
addClass="w388" <img slot="prefix" src="../assets/radio_checked.svg" alt="">
> <!-- 输入框后面小图标 -事件自定义 -->
<!-- 这个 form-top-icon 类名已经有样式除此布局外需要自定义添加样式 --> <i slot="suffix" class="el-icon-close" @click="handleClear"></i>
<div slot="formLeft" class="form-top-icon"> <!-- <img slot="suffix" src="../assets/radio_nochecked.svg" alt="" @click="handleClear"> -->
<img src="../assets/phone-fill.svg" alt="">
<span>手机号码</span> <!-- 这个 appendshow 宽度 居中方式 自定义添加类名修改-->
</div> <!-- <GuipButton slot="appendshow" size="mini">默认按钮</GuipButton> -->
<PhoneCode slot="formDom"></PhoneCode>
</GuipFormItem> <!-- 这个 appendshow 宽度 居中方式 自定义添加类名修改-->
</div> <span slot="appendshow">.checkcopy.com</span>
<el-button type="primary" @click="submitForm">表单Submit</el-button> </GuipInput>
<!-- <el-input placeholder="oieuwroieuwi" style="width:400px;height:60px"></el-input> -->
</div>
<div class="ele-item">
<label for="">单选框</label>
<el-radio v-model="radio1" :label="1">选项一</el-radio>
<el-radio v-model="radio1" :label="2">选项二</el-radio>
</div>
</el-form> <div class="ele-item">
<div style="width: 100%;margin: 20px 0;height: 20px;background-color: antiquewhite;">--------------------分割线0------------------------------</div> <label for="">单选框组</label>
<el-radio-group v-model="radio" @input="radioChange">
<el-radio :label="3">备选项</el-radio>
<el-radio :label="6">备选项</el-radio>
<el-radio :label="9">备选项</el-radio>
</el-radio-group>
</div>
<div class="ele-item">
<label for="">常规按钮</label>
<GuipButton>默认按钮</GuipButton>
<GuipButton type="mild" size="medium">轻度按钮</GuipButton>
<GuipButton type="primary">按钮</GuipButton>
<GuipButton type="reverseMild">按钮</GuipButton>
<GuipButton type="primary" loading>按钮</GuipButton>
<GuipButton type="success" :plain="plain">按钮</GuipButton>
<GuipButton type="info" :plain="plain">按钮</GuipButton>
<GuipButton type="warning" :plain="plain">按钮</GuipButton>
<GuipButton type="danger" :plain="plain">按钮</GuipButton>
</div>
<div class="ele-item">
<label for="">禁用按钮</label>
<GuipButton disabled>默认按钮</GuipButton>
<GuipButton type="mild" disabled size="medium">轻度按钮</GuipButton>
<GuipButton type="reverseMild" disabled>按钮</GuipButton>
<GuipButton type="primary" size="medium" disabled>按钮</GuipButton>
<GuipButton type="success" disabled>按钮</GuipButton>
<GuipButton type="info" disabled>按钮</GuipButton>
<GuipButton type="warning" disabled>按钮</GuipButton>
<GuipButton type="danger" disabled>按钮</GuipButton>
</div>
<div class="ele-item">
<label for="">三种尺寸按钮</label>
<GuipButton type="primary">默认按钮</GuipButton>
<GuipButton type="primary" size="medium">中等按钮</GuipButton>
<GuipButton type="primary" size="small">小的按钮</GuipButton>
<GuipButton type="primary" size="mini">迷你按钮</GuipButton>
</div>
<div class="ele-item">
<label for="">自定义宽高按钮</label>
<GuipButton type="primary" :btnstyle="btnstyleObj">超长啊扭测试长的长的</GuipButton>
<GuipButton type="primary" :btnstyle="btnstyleObj1">随便写的</GuipButton>
</div>
<div style="width: 600px;">
<h3>表单左右布局直接使用封装好的input</h3>
<!-- 表单左右布局 -->
<GuipInput ref="GuipInput" addClass="w510" v-model="form.username" label="Username" prop="username"
:rules="usernameRules" placeholder="这是自定义默认提11示语" />
</div>
<div style="width: 800px;height: 150px;">
<h3>表单上下布局 (宽度 510 388 用的最多 已有这2种宽度类名设置)</h3>
<GuipInput ref="GuipInput" column="column" addClass="w510" label="age" desc="这是是右侧文案" v-model="form.age"
prop="age" placeholder="这是自定义默认提示语" />
</div>
<div style="width: 600px;height: 150px;">
<h3>获取手机验证码(布局也可更改使用插槽自定义展示内容)</h3>
<GuipFormItem column="column" addClass="w388">
<!-- 这个 form-top-icon 类名已经有样式除此布局外需要自定义添加样式 -->
<div slot="formLeft" class="form-top-icon">
<img src="../assets/phone-fill.svg" alt="">
<span>手机号码</span>
</div>
<PhoneCode slot="formDom"></PhoneCode>
</GuipFormItem>
</div>
<el-button type="primary" @click="submitForm">表单Submit</el-button>
</el-form>
<div style="width: 100%;margin: 20px 0;height: 20px;background-color: antiquewhite;">
--------------------分割线0------------------------------</div>
<div style="display: flex;"> <div style="display: flex;">
<!-- <GuipButton type="primary" @click="showModal">弹框</GuipButton> <!-- <GuipButton type="primary" @click="showModal">弹框</GuipButton>
@ -251,47 +237,53 @@
<el-button type="primary" @click="openDialog">打开弹框</el-button> <el-button type="primary" @click="openDialog">打开弹框</el-button>
<GuipDialog <GuipDialog :dialogVisible="dialogVisible" title="自定义标题" :show-close-button="false"
:dialogVisible="dialogVisible" :show-cancel-button="showCancelButton" @confirm="handleConfirm" @cancel="handleCancel" @close="handleClose"
title="自定义标题" @dialogVisibleChange="dialogVisibleChange">
:show-close-button="showCloseButton" <!-- 自定义内容 -->
:show-cancel-button="showCancelButton" <div>
@confirm="handleConfirm" <p>这是一个自定义内容的弹框</p>
@cancel="handleCancel" </div>
@close="handleClose"
@dialogVisibleChange="dialogVisibleChange"
>
<!-- 自定义内容 -->
<div>
<p>这是一个自定义内容的弹框</p>
<el-input placeholder="请输入内容"></el-input>
</div>
</GuipDialog> </GuipDialog>
<!-- <el-switch v-model="switchValue1" active-text="按月付费" inactive-text="按年付费">
</el-switch>
<el-switch style="display: block" v-model="switchValue2" active-color="#13ce66"
active-text="按月付费" inactive-text="按年付费">
</el-switch> -->
<div class="ele-item">
<label for="">开关L</label>
<GuipSwitch :modelValue="switchValue" activeText="开启" inactiveText="关闭" @change="onSwitchChange">
</GuipSwitch>
</div>
</div> </div>
</template> </template>
<script> <script>
import { rules } from "../assets/vabForm"; import { rules } from "../assets/vabForm";
// @ is an alias to /src // @ is an alias to /src
import GuipFormItem from '@/components/GuipFormItem.vue'; import GuipSwitch from '@/components/GuipSwitch.vue';
import GuipDialog from '@/components/GuipDialog.vue'; import GuipFormItem from '@/components/GuipFormItem.vue';
import GuipRadio from '@/components/GuipRadio.vue'; import GuipDialog from '@/components/GuipDialog.vue';
import GuipRadio from '@/components/GuipRadio.vue';
// import GuipForm from '@/components/GuipForm.vue'; // import GuipForm from '@/components/GuipForm.vue';
import PhoneCode from '@/components/PhoneCode.vue'; import PhoneCode from '@/components/PhoneCode.vue';
import GuipButton from '@/components/GuipButton.vue'; import GuipButton from '@/components/GuipButton.vue';
// import GuipConfirm from '@/components/GuipConfirm.vue'; // import GuipConfirm from '@/components/GuipConfirm.vue';
import GuipInput from '@/components/GuipInput.vue'; import GuipInput from '@/components/GuipInput.vue';
// import GuipModal from '@/components/GuipModal.vue'; // import GuipModal from '@/components/GuipModal.vue';
import GuipSelect from '@/components/GuipSelect.vue'; import GuipSelect from '@/components/GuipSelect.vue';
import GuipTable from '@/components/GuipTable.vue'; import GuipTable from '@/components/GuipTable.vue';
import GuipTextarea from '@/components/GuipTextarea.vue' import GuipTextarea from '@/components/GuipTextarea.vue'
export default { export default {
name: 'HomeView', name: 'HomeView',
components: { components: {
GuipTextarea, GuipTextarea,
GuipTable, GuipTable,
GuipSwitch,
// GuipForm, // GuipForm,
GuipDialog, GuipDialog,
GuipRadio, GuipRadio,
@ -303,21 +295,21 @@ import { rules } from "../assets/vabForm";
// GuipModal, // GuipModal,
GuipSelect GuipSelect
}, },
data(){ data() {
return { return {
switchValue: true,
dialogVisible: false,// dialogVisible: false,//
showCancelButton: true, // showCancelButton: true, //
showCloseButton: true, // showCloseButton: true, //
// inputValue: '',
form: { form: {
username: '', username: '',
language:'', language: '',
}, },
languageOptions: [ languageOptions: [
{ label: 'JavaScript', value: 'js' }, { label: 'JavaScript', value: 'js',selectedLabel:'JavaScripthhhhhhhhhh' },
{ label: 'Python', value: 'py' }, { label: 'Python', value: 'py',selectedLabel:'JavaScripthhhhhhhhhh' },
{ label: 'Java', value: 'java', disabled: true }, // { label: 'Java', value: 'java', disabled: true,selectedLabel:'JavaScripthhhhhhhhhh' }, //
{ label: 'Go', value: 'go' }, { label: 'Go', value: 'go' ,selectedLabel:'JavaScripthhhhhhhhhh' },
], ],
rules: { rules: {
username: [ username: [
@ -336,7 +328,7 @@ import { rules } from "../assets/vabForm";
{ required: true, message: '请输入年龄', trigger: 'blur' } { required: true, message: '请输入年龄', trigger: 'blur' }
] ]
}, },
usernameRules:[{ required: true, message: 'Username is required', trigger: 'blur' }],//rules usernameRules: [{ required: true, message: 'Username is required', trigger: 'blur' }],//rules
msg: "测试", msg: "测试",
title: "相关附件", title: "相关附件",
edit: false, edit: false,
@ -359,139 +351,166 @@ import { rules } from "../assets/vabForm";
textareaIner: "textarea", textareaIner: "textarea",
dateTime: "2023-09-12 00:00:00", dateTime: "2023-09-12 00:00:00",
uploadList: [ uploadList: [
{ {
name: "小梨猫.jpg", name: "小梨猫.jpg",
size: 160517, size: 160517,
uid: 1695291434025, uid: 1695291434025,
url: "https://ts1.cn.mm.bing.net/th?id=OIP-C.Zte3ljd4g6kqrWWyg-8fhAHaEo&w=316&h=197&c=8&rs=1&qlt=90&o=6&dpr=1.5&pid=3.1&rm=2", url: "https://ts1.cn.mm.bing.net/th?id=OIP-C.Zte3ljd4g6kqrWWyg-8fhAHaEo&w=316&h=197&c=8&rs=1&qlt=90&o=6&dpr=1.5&pid=3.1&rm=2",
}, },
], ],
}, },
//
tableData: [{
date: '2016-05-03',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄',
price: '20',
age:20,
//
edit_name: '王小虎', edit_address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-02',
name: '王小虎11',
address: '上海市普陀区金沙江路 151811 弄',
price: '10',
age:30,
edit_name: '王小虎11', edit_address: '上海市普陀区金沙江路 151811 弄'
}, {
date: '2016-05-04',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄',
price: '200',
}, {
date: '2016-05-01',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-08',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-06',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-07',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}],
//
columns: [
{ prop: 'name', label: '姓名(带气泡)', popover: true }, //
{ prop: 'age', label: '年龄', popover: true }, //
{ prop: 'address', label: '地址(带气泡)', popover: true }, //
],
optionss: [ optionss: [
{ {
value: "选项1", value: "选项1",
label: "黄金糕", label: "黄金糕",
}, },
{ {
value: "选项2", value: "选项2",
label: "双皮奶", label: "双皮奶",
}, },
{ {
value: "选项3", value: "选项3",
label: "蚵仔煎", label: "蚵仔煎",
}, },
{ {
value: "选项4", value: "选项4",
label: "龙须面", label: "龙须面",
}, },
{ {
value: "选项5", value: "选项5",
label: "北京烤鸭", label: "北京烤鸭",
}, },
], ],
cities: [ cities: [
{ {
value: "Beijing", value: "Beijing",
label: "北京", label: "北京",
}, },
{ {
value: "Shanghai", value: "Shanghai",
label: "上海", label: "上海",
}, },
{ {
value: "Nanjing", value: "Nanjing",
label: "南京", label: "南京",
}, },
{ {
value: "Chengdu", value: "Chengdu",
label: "成都", label: "成都",
}, },
{ {
value: "Shenzhen", value: "Shenzhen",
label: "深圳", label: "深圳",
}, },
{ {
value: "Guangzhou", value: "Guangzhou",
label: "广州", label: "广州",
} }
], ],
input:'hahhahah', input: 'hahhahah',
defaultValue:'asdasda', defaultValue: 'asdasda',
radio:3, radio: 3,
radio1:5, radio1: 5,
btnstyleObj:{ btnstyleObj: {
width: '247px', width: '247px',
height: '44px', height: '44px',
background: '#F2F7FF', background: '#F2F7FF',
borderRadius: '2px', borderRadius: '2px',
fontSize:'14px', fontSize: '14px',
letterSpacing: '0.08em', letterSpacing: '0.08em',
color: '#006AFF !important' color: '#006AFF !important'
}, },
btnstyleObj1:{ btnstyleObj1: {
width: '180px', width: '180px',
height: '40px', height: '40px',
}, },
styleObject:{ styleObject: {
width:'200px', width: '200px',
height:'40px' height: '40px'
}, },
styleObject1:{ styleObject1: {
width:'600px', width: '600px',
height:'50px' height: '50px'
}, },
plain:false, plain: false,
tableData: [{
date: '2016-05-03',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄',
price:'20',
}, {
date: '2016-05-02',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄',
price:'10',
}, {
date: '2016-05-04',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄',
price:'200',
}, {
date: '2016-05-01',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-08',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-06',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}, {
date: '2016-05-07',
name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄'
}],
options: [{ options: [{
value: '选项1', value: '选项1',
label: '黄金糕' label1:'黄金hhhhhh',
label: '黄金糕'
}, { }, {
value: '选项2', value: '选项2',
label: '双皮奶' label1:'双皮奶hhhhhhhhh',
label: '双皮奶'
}, { }, {
value: '选项3', value: '选项3',
label: '蚵仔煎' label1:'蚵仔煎hhhhhhhhh',
label: '蚵仔煎'
}, { }, {
value: '选项4', value: '选项4',
label: '龙须面' label1:'双皮奶hhhhhhhhh',
label: '龙须面'
}, { }, {
value: '选项5', value: '选项5',
label: '北京烤鸭' label1:'双皮奶hhhhhhhhh',
label: '北京烤鸭'
}], }],
} }
}, },
methods:{ methods: {
// key
random(){
var randomNumber = Math.random();
return randomNumber
},
onSwitchChange(value) {
console.log('Switch 状态变化:', value);
},
// ---start // ---start
openDialog() { openDialog() {
this.dialogVisible = true; this.dialogVisible = true;
@ -511,8 +530,8 @@ import { rules } from "../assets/vabForm";
this.$message.info('弹框已关闭'); this.$message.info('弹框已关闭');
this.dialogVisible = false; this.dialogVisible = false;
}, },
dialogVisibleChange(data){ dialogVisibleChange(data) {
console.log(data,'data098908090'); console.log(data, 'data098908090');
}, },
// ---end // ---end
@ -522,20 +541,37 @@ import { rules } from "../assets/vabForm";
this.editedPrice = row.price; this.editedPrice = row.price;
this.dialogVisible = true; this.dialogVisible = true;
}, },
// -----
//
onConfirm(row, prop) {
console.log('确认修改:', row, prop);
this.$message.success('修改成功');
this.$set(this.tableData,row)
console.log(this.tableData,'this.tableData=====');
},
//
onCancel(row, prop) {
console.log('取消修改:', row, prop);
this.$message.info('已取消');
this.$set(this.tableData,row)
},
// -----
// //
radioChange(data){ radioChange(data) {
console.log(data,'radio--data'); console.log(data, 'radio--data');
}, },
handleClick(row) { handleClick(row) {
console.log(row); console.log(row);
}, },
submitForm() { submitForm() {
this.$refs.formRef.validate((valid) => { this.$refs.formRef.validate((valid) => {
console.log(this.form,'======formxinxi'); console.log(this.form, '======formxinxi');
if (valid) { if (valid) {
alert('提交成功!'); alert('提交成功!');
} else { } else {
return false; return false;
} }
}); });
}, },
@ -546,47 +582,47 @@ import { rules } from "../assets/vabForm";
triggerError() { triggerError() {
this.$refs.formRef.validateField('username', (error) => { this.$refs.formRef.validateField('username', (error) => {
if (error) { if (error) {
console.log('错误信息:', error); console.log('错误信息:', error);
} else { } else {
console.log('无错误'); console.log('无错误');
} }
}); });
}, },
getFormdata(){ getFormdata() {
console.log(this.$refs.GuipInput.value); console.log(this.$refs.GuipInput.value);
}, },
handleInput(value){ handleInput(value) {
console.log(value,'value===输入框输入得知'); console.log(value, 'value===输入框输入得知');
}, },
handleClear(value){ handleClear(value) {
this.defaultValue = '这是我清除后给的文案' this.defaultValue = '这是我清除后给的文案'
// this.handleInput('') // this.handleInput('')
console.log(value,'value===qinghcu'); console.log(value, 'value===qinghcu');
}, },
getList() { getList() {
const dataList = rules(); const dataList = rules();
dataList.forEach((item) => { dataList.forEach((item) => {
if (item.field === "id") { if (item.field === "id") {
item.options = this.cities; item.options = this.cities;
} }
if (item.field === "id1") { if (item.field === "id1") {
item.options = this.optionss; item.options = this.optionss;
} }
}); });
this.formList = dataList; this.formList = dataList;
}, },
save() { save() {
this.$refs.VabForm.submitForm("ruleForm"); this.$refs.VabForm.submitForm("ruleForm");
}, },
// //
cancellation() { cancellation() {
this.$refs.VabForm.resetForm("ruleForm"); this.$refs.VabForm.resetForm("ruleForm");
}, },
// //
handleSelectionChange(data){ handleSelectionChange(data) {
// data // data
// //
console.log(data,'表格行信息'); console.log(data, '表格行信息');
}, },
// //
toggleAllSelection() { toggleAllSelection() {
@ -598,44 +634,46 @@ import { rules } from "../assets/vabForm";
this.getList(); this.getList();
}, },
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.elementWrap{ .elementWrap {
/* width: 100%; */ /* width: 100%; */
padding: 30px 40px; padding: 30px 40px;
.ele-item{
display: flex; .ele-item {
align-items: center; display: flex;
justify-content: flex-start; align-items: center;
margin-bottom: 30px; justify-content: flex-start;
label{ margin: 20px 0 30px;
font-size: 16px;
font-weight: bold; label {
width: 100px; font-size: 16px;
margin-right: 10px; font-weight: bold;
text-align: left; width: 100px;
} margin-right: 10px;
text-align: left;
} }
} }
}
.ScaleBox { .ScaleBox {
width: 1000px; width: 1000px;
background-size: 100% 100%; background-size: 100% 100%;
-ms-transition: 0.3s; -ms-transition: 0.3s;
transition: 0.3s; transition: 0.3s;
-ms-transform-origin: 0 0; -ms-transform-origin: 0 0;
transform-origin: 0 0; transform-origin: 0 0;
margin: 0 auto; margin: 0 auto;
} }
.cardfooter { .cardfooter {
width: 100%; width: 100%;
// position: fixed; // position: fixed;
bottom: 20px; bottom: 20px;
right: 30px; right: 30px;
text-align: right; text-align: right;
justify-content: center; justify-content: center;
} }
</style> </style>
Loading…
Cancel
Save