jquery 一个标签选择的实现 请教请教
现在要做的就是最多可以选择三个标签,选中的标签要在“选择标签”那一栏里面显示。
标签都是span元素,“选择标签”那一栏是个input。
这个效果该怎么实现呢?请教jquery高手 ,谢谢 ~
回复内容:
现在要做的就是最多可以选择三个标签,选中的标签要在“选择标签”那一栏里面显示。
标签都是span元素,“选择标签”那一栏是个input。
这个效果该怎么实现呢?请教jquery高手 ,谢谢 ~
假定你这些标签的数据都是从后端渲染的,那么就会有相应的id和值,假设页面渲染出来是这个效果
<code><div class="container"> <div class="input-group input-group-sm"> <input type="text" class="form-control" id="input" readonly> <span class="input-group-addon" id="certainBtn">确定</span> </div> <div class="btn-group btn-group-sm mt" id="labels"> <span type="button" class="btn btn-default" data-id="1" data-value="公司运营">公司运营</span> <span type="button" class="btn btn-default" data-id="2" data-value="互联网营销">互联网营销</span> <span type="button" class="btn btn-default" data-id="3" data-value="组织变革">组织变革</span> <span type="button" class="btn btn-default" data-id="4" data-value="招聘/激励">招聘/激励</span> <span type="button" class="btn btn-default" data-id="5" data-value="品牌公关">品牌公关</span> <span type="button" class="btn btn-default" data-id="6" data-value="财务/法务">财务/法务</span> </div> </div> (function ($) { var $labels = $('#labels'); //标签栏 var $input = $('#input'); //输入框 var $certainBtn=$('#certainBtn'); //确定按钮 var data = {};//已选择的数据 var max = 3; //最多选择数目 var activeClass = 'btn-primary'; //选中的active样式 $labels.on('click', 'span', function () { var $this = $(this); var id = $this.data('id'); var value = $this.data('value'); var isSelected = $this.hasClass(activeClass);//是否被选中 //超过数目限制则不做处理 if (!isSelected && Object.keys(data).length >= max) { return; } isSelected ? delete data[id] : data[id] = value; $this.toggleClass(activeClass); renderInput(); }); $certainBtn.click(function () { console.log(data); }); function renderInput() { var values = []; for (var id in data) { values.push(data[id]); } $input.val(values.toString()); //with underscore //$input.val(_.values(data).toString()); } })(jQuery); </code>
采用组件化的思想重新写一个
<code>(function($){ var labelChoose = { el: { $labels: $('#labels'), $input: $('#input'), $certainBtn: $('#certainBtn') }, max: 3, data: {}, activeClass: 'btn-primary', init: function (defaultData) { var self = this; this.renderInit(defaultData); //初始化 this.el.$labels.on('click', 'span', function (e) { self.labelsClick(e); }); this.el.$certainBtn.on('click', function (e) { self.certainClick(e); }); }, labelsClick: function (e) { var $this = $(e.currentTarget); var id = $this.data('id'); var value = $this.data('value'); var isSelected = $this.hasClass(this.activeClass);//是否被选中 //超过数目限制则不做处理 if (!isSelected && Object.keys(this.data).length >= this.max) { return; } isSelected ? delete this.data[id] : this.data[id] = value; $this.toggleClass(this.activeClass); this.renderInput(); }, renderLabels: function () { var self = this; this.el.$labels.find('span').each(function () { var $this = $(this); var id = $this.data('id'); for (var idz in self.data) { if (idz === id.toString()) { $this.addClass(self.activeClass); } } }); }, renderInput: function () { var values = []; for (var id in this.data) { values.push(this.data[id]); } //with underscore //this.el.$input.val(_.values(this.data).toString()); this.el.$input.val(values.toString()); }, certainClick: function (e) { console.log(this.data); }, renderInit: function (defaultData) { this.data = defaultData || {}; this.renderLabels(); this.renderInput(); } }; labelChoose.init({ '1': '公司运营', '2': '互联网营销' }); })(jQuery); </code>
由于涉及到数据操作和this绑定,和underscore结合起来使用会比较好点,以上代码仅供参考!
大概要做这么几件事:
<code>1.定义显示被选中的标签的函数 2.在每个标签上设置点击事件 </code>
在每次点击标签的时候,把当前的this标签传到1的函数里,append到input的value里。
这种插件自己写的话会很麻烦 建议直接用插件去实现
给你说两个吧 都是我经常用到的:
select2 和 flatui(前端UI框架)
点进去看看文档稍有JQ基础都可以做出你想要的效果。
我再简单描述一下自己写代码要怎么实现:
input框里肯定是要有CSS和JS来控制的
span标签添加点击事件,点击后加个display:none
的style(并不是删除 方便在input中点击移除后重新展现)。
假定span有个id叫sp1 input的id叫show,大概的思路是这样的:
<code>$('#sp1').click(function(){ $(this).css('display','none'); //获取span中的值复制给input $('#show').val($(this).html()); }) </code>
span中的值赋值给input久做好了,但是如果在input点击后取消显示就有一些复杂了,你需要定制一些样式,最起码input中的值可以点击并且触发事件。我就说这么多,起到抛砖引玉的作用。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

HTML 테이블 레이아웃 안내. 여기에서는 HTML 테이블 레이아웃의 값에 대해 예제 및 출력 n 세부 사항과 함께 논의합니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는
