用户信息在数据库是json在界面展示与修改

本文介绍如何使用Laravel框架和Vue.js实现用户的个人设置功能,包括从数据库加载JSON格式的用户设置到前端展示,并允许用户进行修改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#用户信息在数据库是json在界面展示与修改

PHP:7.2.2
Laravel:5.5.40
Vue:2.5

用户的基本信息是以setting字段以json数据类型在数据库存放

数据库中的数据

界面的展示

现在需要对用户的个人设置进行展示与修改

##1. 路由routes/web.php

Route::get("/setting",'SettingController@index')->name('setting');//用户设置面板
Route::post("/setting",'SettingController@store')->name('setting');//用户设置保存

##2. 个人设置的模型app\Models\Setting.php

<?php

namespace App\models;

/**
 * 用户信息设置的模型
 *
 * Class Setting
 * @package App\models
 */
class Setting
{
    /**
     * @var array 用户设置的字段
     */
    protected $allowd = ['city', 'site', 'github', 'bio'];

    /**
     * @var User 需要修改信息的用户
     */
    protected $user;

    /**
     * Setting constructor.
     * @param $user
     */
    public function __construct(User $user)
    {
        $this->user = $user;
    }

    /**
     * 用户保存自己的信息时使用
     *
     * @param array $attributes
     * @return bool
     */
    public function merge(array $attributes)
    {
        $settings = array_merge($this->user->setting, array_only($attributes, $this->allowd));
        return $this->user->update(['setting' => $settings]);
    }
}

##3. 用户中添加个人设置方法app/Models/User.php

/**
 * 设置用户的信息
 *
 * @return Setting
 */
public function settings()
{
    return new Setting($this);
}

##4. 用户个人设置的控制器app/Http/Controllers/SettingController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

/**
 * 用户个人设置控制器
 *
 * Class SettingController
 * @package App\Http\Controllers
 */
class SettingController extends Controller
{
    /**
     * SettingController constructor.
     */
    public function __construct()
    {
        $this->middleware('auth');
    }

    /**展示用户的个人设置
     *
     *
     * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
     */
    public function index(){
        return view('users.setting');
    }

    /**
     * 保存个人设置的操作
     *
     * @param Request $request
     * @return \Illuminate\Http\RedirectResponse
     */
    public function store(Request $request){
        user()->settings()->merge($request->all());
        return back();
    }
}

##5. 前端界面resources/views/users/setting.blade.php

@extends('layouts.app')

@section('title','个人设置')

@section('content')
    <div class="container">
        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <div class="panel panel-default">
                    <div class="panel-heading">个人设置</div>

                    <div class="panel-body">
                        <form class="form-horizontal" role="form" method="POST" action="{{ url('/setting') }}">
                            {{ csrf_field() }}

                            <div class="form-group{{ $errors->has('city') ? ' has-error' : '' }}">
                                <label for="city" class="col-md-4 control-label">现居城市</label>

                                <div class="col-md-6">
                                    <input id="city" type="text" class="form-control" name="city"
                                           value="{{ user()->setting['city'] }}" required>

                                    @if ($errors->has('city'))
                                        <span class="help-block">
                                        <strong>{{ $errors->first('city') }}</strong>
                                    </span>
                                    @endif
                                </div>
                            </div>

                            <div class="form-group{{ $errors->has('site') ? ' has-error' : '' }}">
                                <label for="site" class="col-md-4 control-label">个人站点</label>

                                <div class="col-md-6">
                                    <input id="site" type="text" class="form-control" name="site"
                                           value="{{user()->setting['site']}}" required>

                                    @if ($errors->has('site'))
                                        <span class="help-block">
                                        <strong>{{ $errors->first('site') }}</strong>
                                    </span>
                                    @endif
                                </div>
                            </div>

                            <div class="form-group{{ $errors->has('github') ? ' has-error' : '' }}">
                                <label for="github" class="col-md-4 control-label">Github</label>

                                <div class="col-md-6">
                                    <input id="github" type="text" class="form-control" name="github"
                                           value="{{user()->setting['github']}}" required>

                                    @if ($errors->has('github'))
                                        <span class="help-block">
                                        <strong>{{ $errors->first('github') }}</strong>
                                    </span>
                                    @endif
                                </div>
                            </div>

                            <div class="form-group{{ $errors->has('bio') ? ' has-error' : '' }}">
                                <label for="bio" class="col-md-4 control-label">个人简介</label>

                                <div class="col-md-6">
                                    <textarea id="bio" type="text" class="form-control" name="bio"
                                              required>{{user()->setting['bio']}}</textarea>

                                    @if ($errors->has('bio'))
                                        <span class="help-block">
                                        <strong>{{ $errors->first('bio') }}</strong>
                                    </span>
                                    @endif
                                </div>
                            </div>


                            <div class="form-group">
                                <div class="col-md-6 col-md-offset-4">
                                    <button type="submit" class="btn btn-primary btn-block">
                                        更改资料
                                    </button>
                                </div>
                            </div>

                        </form>
                    </div>
                </div>
            </div>
        </div>
    </div>
@endsection

### 根据 MySQL 数据库字段值在前端页面显示不同颜色 为了实现在 UI 界面根据 MySQL 数据库中的字段值来动态改变元素的颜色,可以采用以下方法: #### 1. 后端处理逻辑 通过 Servlet 或者 Spring Boot 应用程序连接到 MySQL 数据库并获取所需的数据。使用 `Class.forName("com.mysql.cj.jdbc.Driver")` 来加载 JDBC 驱动程序[^2]。 ```java // 加载JDBC驱动器 try { Class.forName("com.mysql.cj.jdbc.Driver"); } catch (ClassNotFoundException e) { System.out.println("Where is your MySQL JDBC Driver?"); e.printStackTrace(); } ``` 接着执行 SQL 查询语句以检索特定记录,并将这些数据传递给前端应用。 #### 2. 前端 JavaScript 实现 从前端的角度出发,在接收到服务器返回的数据之后,可以根据具体的业务需求编写条件判断语句来设置样式类或直接操作 DOM 的 style 属性从而达到更改背景色的效果。 假设有一个名为 status 的列用于表示状态码(0 表示失败;1 表示成功),那么可以在 HTML 文件中定义如下 CSS 类: ```css .success { background-color:green; color:white;} .failure {background-color:red;color:white;} ``` 再利用 AJAX 技术从服务端拉取 JSON 形式的响应体,解析其中的状态信息后为对应的 div 添加上述预设好的 class 名字即可完成视觉上的区分效果。 ```javascript fetch('/api/getStatus') .then(response => response.json()) .then(data => { const element = document.getElementById('statusElement'); if (data.status === 'success') { element.classList.add('success'); } else if (data.status === 'failure'){ element.classList.add('failure'); } }); ``` 对于更复杂的情况比如数值范围映射成渐变色彩,则可能需要用到 d3.js 这样的可视化库来进行辅助开发工作。 #### 3. 结合加密字段展示 如果涉及到加密后的数据显示问题,考虑到性能因素以及用户体验度量标准,建议先解密再渲染至客户端浏览器上呈现出来。当遇到需要模糊匹配查询时,应该尽可能减少不必要的计算开销,因此最好是在应用程序层面而非数据库层面对字符串进行过滤筛选[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值