HTML如何用element-ui快速做出个人信息界面

如何快速用element-ui做一个用户中心

如图所示

当点击编辑以后如下图所示

一.引入

首先要引入vue.je和element

复制代码
<script type="text/javascript" src="js/vue-2.5.16.js"></script> <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"> <script src="https://unpkg.com/element-ui/lib/index.js"></script>

vue.js我在本地就有了,所以直接用路径引入了

二.html部分

复制代码
 <div>
        <el-form label-width="80px" size="small">
            <el-form-item label="邮箱">
                <el-input v-model="email" :disabled="!editMode" style="width: 200px;"></el-input>
            </el-form-item>
            <el-form-item label="电话">
                <el-input v-model="phone" :disabled="!editMode" style="width: 200px;"></el-input>
            </el-form-item>
            <el-form-item label="简介">
    <el-input type="textarea" v-model="bio" :disabled="!editMode" style="width: 300px; height: 100px;"></el-input>
</el-form-item>
            <el-form-item label="头像">
                <el-image :src="profile" style="width: 100px; height: 100px;"></el-image>
                <el-button type="text" icon="el-icon-picture" @click="uploadAvatar" v-if="editMode">修改头像</el-button>
            </el-form-item>
        </el-form>
        <div style="margin-left: 25px;">
            <el-button type="primary" @click="editMode = true" v-if="!editMode">编辑</el-button>
            <el-button type="success" @click="saveUserInfo" v-if="editMode">保存</el-button>
            <el-button type="danger" @click="cancelEdit" v-if="editMode">取消</el-button>
        </div>
    </div>

使用了<el-form>来构筑表单

在非编辑模式,即!editMode时不可选中

当点击编辑以后,@click="editMode = true,令editMode变为True,也就是变成可编辑模式

在可编辑模式时,编辑按钮会隐藏,而保存和取消按钮会显示。修改头像按钮也是同理。

三.Js部分

取消按钮

复制代码
cancelEdit() {
    // 用户点击取消按钮,退出编辑模式,不保存修改的信息
    this.editMode = false;
    this.getUserInfo();
},

保存按钮

复制代码
saveUserInfo() {

    axios.post('http://127.0.0.1:8000/user/get_userinfo/', {
        email: this.email,
        mobile: this.phone,
        bio:this.bio,
    }, {
        withCredentials: true,
    })
    .then(response => {
        console.log("用户信息保存成功");
        this.editMode = false; // 保存成功后退出编辑模式
    })
    .catch(error => {
        console.error('There was an error!', error);
    });
},

修改头像

复制代码
        uploadAvatar() {
    const inputElement = document.createElement('input');
    inputElement.type = 'file';
    inputElement.accept = 'image/*';
    inputElement.onchange = (event) => {
        const file = event.target.files[0];
        const formData = new FormData();
        formData.append('avatar', file);
        axios.post('http://127.0.0.1:8000/user/upload_avatar/', formData, {
            headers: {
                'Content-Type': 'multipart/form-data',
            },
            withCredentials: true,
        })
        .then(response => {
            console.log("头像上传成功");
Vue.set(this, 'profile', response.data.profile_url);
window.location.reload();
        })
        .catch(error => {
            console.error('There was an error!', error);
        });
    };
    inputElement.click();
},
相关推荐
D_C_tyu几秒前
HTML | 结合Canvas开发具有智能寻路功能的贪吃蛇小游戏实战详解
javascript·算法·游戏·html·bfs
Jay-r3 分钟前
樱花雨特效 WebGL实现 短视频同款浪漫视觉效果(附源码下载)
开发语言·javascript·ecmascript·编程·webgl·代码·樱花雨
凤山老林4 分钟前
Js如何实现一个抽奖程序
前端·javascript·vue.js
我命由我123455 分钟前
React - Switch、路由精准匹配与模糊匹配、Redirect
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
陆枫Larry12 分钟前
用 Git 别名(Alias)简化日常操作
前端
阿泽·黑核15 分钟前
Easy Vibe Coding 学习心得(三):前端之美——从设计稿到精美界面
前端·vibe coding·easy vibe
无心水25 分钟前
【时间利器】4、JavaScript时间处理全解:Date/moment/dayjs/Temporal
开发语言·前端·javascript·状态模式·openclaw·date/moment·dayjs/temporal
踩着两条虫30 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(二十五):API与参考之Renderer API 参考
前端·vue.js·人工智能
踩着两条虫30 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(二十四):API与参考之Provider API 参考
前端·vue.js·ai编程
恋猫de小郭36 分钟前
Android Studio Panda 2 ,支持 AI 用 Vibe Coding 创建项目
android·前端·flutter