How to click on the header and make the corresponding column editable in the vue project?

the user table requires a new list of custom names. After clicking on the custom name of the header, the column enters editable mode.
initially thought about the label and input switching controlled by v-if (code below), but it had no effect. In addition, I also think it"s stupid to do so. Is there any better way?

<table class="table baseTable">
    <thead>
        <tr>
            <th></th>
            <th></th>
            <th><span @click="isEdit=isEdit"></span></th>
            <th></th>
        </tr>
    </thead>
    <tbody>
        <tr v-for="(item,index) in infoList" v-bind:key="index">
            <td>{{index+1+10*(currentPage-1)}}</td>
            <td>{{item.displayName}}</td>
            <td>
                <label v-if="isEdit == false">{{item.customName}}</label>
                <div v-else>
                    <input  v-model="item.customName"/>
                    <button @click="isEdit =isEdit"></button>
                </div>
            </td>
            <td>{{item.userName}}</td>
        </tr>
    </tbody>
</table>
Mar.17,2021

you have to think right, and there's no problem copying your code and testing it. The only problem is isEditskills! The exclamation point of isEdit is in Chinese.

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1e43e55-26fab.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1e43e55-26fab.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?