123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- <template>
- <div class="app-container calendar-list-container">
- <!-- 查询和其他操作 -->
- <div class="filter-container">
- <el-button class="filter-item" type="primary" :loading="downloadLoading" v-waves icon="el-icon-download" @click="handleDownload">导出</el-button>
- </div>
- <!-- 查询结果 -->
- <el-table size="small" :data="list" v-loading="listLoading" element-loading-text="正在查询中。。。" border fit highlight-current-row>
- <!--<el-table-column align="center" width="100px" label="用户ID" prop="id" sortable>
- </el-table-column>-->
- <el-table-column type="index" label="序号" header-align="center" align="center">
- </el-table-column>
- <el-table-column align="center" min-width="100px" label="头像" prop="photo">
- <template slot-scope="scope">
- <img :src="scope.row.photo" style="width: 50px;height: 50px;border-radius: 50%"/>
- </template>
- </el-table-column>
- <el-table-column align="center" min-width="100px" label="用户名" prop="userName">
- </el-table-column>
- <el-table-column align="center" min-width="50px" label="性别" prop="gender">
- </el-table-column>
- <el-table-column align="center" min-width="100px" label="手机号" prop="phone">
- </el-table-column>
- <el-table-column align="center" min-width="100px" label="邮箱" prop="email">
- </el-table-column>
- <el-table-column align="center" min-width="100px" label="角色" prop="roleType">
- </el-table-column>
- <!--<el-table-column align="center" label="操作" width="200" class-name="small-padding fixed-width">
- <template slot-scope="scope">
- <router-link ref='tag' :to="{path:'/user/userDetail',query: {'id': scope.row.id}}">
- <el-button class="filter-item" type="primary" size="mini" style="width: inherit;" v-waves icon="el-icon-search">用户详情</el-button>
- </router-link>
- </template>
- </el-table-column>-->
- </el-table>
- <!-- 分页 -->
- <div class="pagination-container">
- <el-pagination background @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="listQuery.page"
- :page-sizes="[10,20,30,50]" :page-size="listQuery.limit" layout="total, sizes, prev, pager, next, jumper" :total="total">
- </el-pagination>
- </div>
- </div>
- </template>
- <script>
- import { fetYKList } from '@/api/user'
- import waves from '@/directive/waves' // 水波纹指令
- export default {
- name: 'visitorUser',
- directives: {
- waves
- },
- data() {
- return {
- list: null,
- total: null,
- listLoading: true,
- listQuery: {
- page: 1,
- limit: 20,
- userName: undefined,
- roleType: undefined,
- sort: '+id'
- },
- dialogFormVisible: false,
- dialogStatus: '',
- downloadLoading: false
- }
- },
- created() {
- this.getList()
- },
- methods: {
- getList() {
- this.listLoading = true
- fetYKList(this.listQuery).then(response => {
- this.list = response.data.data.items
- console.log(this.list)
- this.total = response.data.data.total
- this.listLoading = false
- }).catch(() => {
- debugger
- this.list = []
- this.total = 0
- this.listLoading = false
- })
- },
- handleFilter() {
- this.listQuery.page = 1
- this.getList()
- },
- handleSizeChange(val) {
- this.listQuery.limit = val
- this.getList()
- },
- handleCurrentChange(val) {
- this.listQuery.page = val
- this.getList()
- },
- handleDownload() {
- this.downloadLoading = true
- import('@/vendor/Export2Excel').then(excel => {
- const tHeader = ['用户名', '性别', '角色']
- const filterVal = ['userName','gender', 'roleType']
- excel.export_json_to_excel2(tHeader, this.list, filterVal, '游客用户信息')
- this.downloadLoading = false
- })
- }
- }
- }
- </script>
|