首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >选择项目后更改下拉菜单中的按钮innerHTML

选择项目后更改下拉菜单中的按钮innerHTML
EN

Stack Overflow用户
提问于 2020-10-23 23:50:05
回答 1查看 66关注 0票数 0

我使用alpineJs来显示带有标志的语言选择器。

在选择另一种语言后,我需要更改按钮的内容(语言+标志),我不知道如何在按钮和下拉菜单的项目之间进行链接,活动语言不应该出现在下拉菜单中。

代码语言:javascript
复制
<button class="w-full hb:w-4/5 flex items-center px-4 py-3 text-gray-900 bg-gray-300 rounded-sm cursor-pointer focus:outline-none"
    x-on:click="langSelector = true"
>
    <img class="w-4 inline-block rounded-sm" src="https://media.flaticon.com/dist/min/img/flags/fr.svg">
    <span class="ml-2 font-medium">Français</span>
    <svg class="w-3 h-3 ml-auto" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
        <path stroke-linecap="round" stroke-linejoin="round" stroke-width="3" d="M19 9l-7 7-7-7"></path>
    </svg>
</button>
<ul class="w-full absolute left-0 hb:w-4/5 py-1 pb-2 px-4 bg-gray-900 text-white font-normal rounded-sm"
    x-cloak x-show.transition.origin.top="langSelector"
    x-on:click.away="langSelector = false"
>
    <template x-for="lang in langs" :key="lang.id">
        <li class="pt-2" :id="lang.id"
            @click="activeLang = lang.id"
        >
            <a href="#" class="flex items-center hover:text-green-100 hover:font-medium">
                <img class="w-4 inline-block rounded-sm" :src="`https://media.flaticon.com/dist/min/img/flags/${lang.abv}.svg`">
                <span class="ml-2" x-text="lang.title"></span>
            </a>
        </li>
    </template>
</ul>

下面是我所取得的成果的https://codepen.io/alchy/pen/ExyZZgg代码

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-24 01:38:29

这是正常工作的代码。你只要检查一下就行了。

代码语言:javascript
复制
<div class="w-1/3 mx-auto relative" x-data="{ 
             langSelector: false, 
             activeLang : 0,
             langs : [
             { id: 0, title: 'Français', abv: 'fr' },
             { id: 1, title: 'English', abv: 'en' },
             { id: 2, title: 'Español', abv: 'es' }
             ] 
             }">
    <button class="w-full hb:w-4/5 flex items-center px-4 py-3 text-gray-900 bg-gray-300 rounded-sm cursor-pointer focus:outline-none" x-on:click="langSelector = true"> <img class="w-4 inline-block rounded-sm" :src="'https://media.flaticon.com/dist/min/img/flags/' + langs[activeLang].abv + '.svg'"> <span class="ml-2 font-medium" x-html=[langs[activeLang].title]>Français</span>
        <svg class="w-3 h-3 ml-auto" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
            <path stroke-linecap="round" stroke-linejoin="round" stroke-width="3" d="M19 9l-7 7-7-7"></path>
        </svg>
    </button>
    <ul class="w-full absolute left-0 hb:w-4/5 py-1 pb-2 px-4 bg-gray-900 text-white font-normal rounded-sm" x-cloak x-show.transition.origin.top="langSelector" x-on:click.away="langSelector = false">
        <template x-for="lang in langs" :key="lang.id">
            <li class="pt-2" :id="lang.id" @click="activeLang = lang.id, langSelector = false" x-show="activeLang != lang.id">
                <a href="#" class="flex items-center hover:text-green-100 hover:font-medium"> <img class="w-4 inline-block rounded-sm" :src="`https://media.flaticon.com/dist/min/img/flags/${lang.abv}.svg`"> <span class="ml-2" x-text="lang.title"></span> </a>
            </li>
        </template>
    </ul>
</div>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64503294

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档