如何使用 jquery 将列表项附加到另一个列表的 beginning/end?
How to append items of list at the beginning/end of another list using jquery?
我有 2 个 ul 和一组 list.I 想要在第一个列表中附加第二个列表的项目,如图所示
List 1
<ul class="thumbicon"> <!-- need to append the class 'flex-direction-nav' -->
<!-- append prev li -->
<li>item 1<li>
<li>item 2<li>
<li>item 3<li>
<!-- append next li -->
</ul>
List 2
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
我想要的
<ul class="thumbicon flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li>item 1<li>
<li>item 2<li>
<li>item 3<li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
在jquery中可以这样做吗?
$('ul:first-child').append('<li>...</li>');
你可以这样试试
首先将第一个 ul
中的 类 添加到第二个,然后将 li
添加到第一个 li
之后的第二个 ul
,最后删除第一个 ul
$('.flex-direction-nav')
.addClass($('ul.thumbicon')
.attr('class'))
.find('li:first')
.append($('ul.thumbicon').children())
$('ul:first').remove()
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
或者如果你想从第二个追加到第一个 div 你可以这样做。
$('.thumbicon')
.addClass($('ul.flex-direction-nav').attr('class'))
.prepend($('ul:eq(1) li:eq(0)'))
.append($('ul:eq(1) li:eq(0)'))
$('ul:eq(1)').remove()
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
Select 第一里使用 :first
and append it at the first of target ul using .prependTo()
and select second (that in this case is last) li using :last
and append it at the end of target ul using .appendTo()
.
$(".flex-direction-nav > li:first").prependTo(".thumbicon");
$(".flex-direction-nav > li:last").appendTo(".thumbicon");
$(".flex-direction-nav").remove();
$(".flex-direction-nav > li:first").prependTo(".thumbicon");
$(".flex-direction-nav > li:last").appendTo(".thumbicon");
$(".flex-direction-nav").remove();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
List 1
<ul class="thumbicon">
<li>item 1<li>
<li>item 2<li>
<li>item 3<li>
</ul>
List 2
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
你也可以在一行中完成这项工作jquery
$(".flex-direction-nav > li").prependTo(".thumbicon").last().appendTo(".thumbicon");
$(".flex-direction-nav").remove();
就像
一样简单
$('.thumbicon').append($next).prepend($prev).addClass('flex-direction-nav');
var $next = $('.flex-nav-next');
var $prev = $('.flex-nav-prev');
$('.flex-direction-nav').remove(); // If you needed
$('.thumbicon').append($next).prepend($prev).addClass('flex-direction-nav');
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
虽然这很容易写在 jQuery 中,但我还想展示一个简单的 JavaScript 解决方案:
// using a named function, to enable re-use if required:
function wrapWithNavigation() {
// initialising variables with 'let' rather than 'var',
// this requires an ES6-compatible browser, but can be
// made ES5 compatible by replacing 'let' with 'var'.
// retrieving the first - if any - elements that match
// the supplied CSS selectors:
let source = document.querySelector('.thumbicon'),
navigationSource = document.querySelector('.flex-direction-nav');
// converting the NodeList of the navigationSource's child elements
// (note 'children' an not 'childNodes') into an Array, and
// iterating over that Array using Array.prototype.forEach() with
// an Arrow function (again, this requires ES6-compatibility):
Array.from(navigationSource.children).forEach(
// navigationChild is a reference to the current Array-element
// of the Array of child-elements over which we're iterating:
navigationChild => {
// if the text-content, converted to lowercase, of the
// element contains the string 'prev':
if (navigationChild.textContent.toLowerCase().indexOf('prev') > -1) {
// we then insert the child-element before the the first-child
// of the source element, using ParentNode.insertBefore():
source.insertBefore(navigationChild, source.firstChild);
// otherwise if the lowercase text-content contains the string
// 'next' we use Node.appendChild() to add the current child-
// element as the last-child of the source element:
} else if (navigationChild.textContent.toLowerCase().indexOf('next') > -1) {
source.appendChild(navigationChild);
}
});
// we use the Element.classList API to add class-names to
// the source element:
source.classList.add(
// we convert the classList (an Array-like list of
// class-names) of the navigationSource element into
// a String, using Array.prototype.join(), to create
// a comma-separated String of class-names to pass to
// the add() method of the Element.classList API:
Array.from(navigationSource.classList).join()
)
// we then find the parent-node of the navigationSource
// element, and remove the navigationSource element using
// parentNode.removeChild() (this wasn't mentioned in the
// question, and if you wish to retain the navigationSouce
// element this line can be omitted):
navigationSource.parentNode.removeChild(navigationSource);
}
wrapWithNavigation();
function wrapWithNavigation() {
let source = document.querySelector('.thumbicon'),
navigationSource = document.querySelector('.flex-direction-nav');
Array.from(navigationSource.children).forEach(
navigationChild => {
if (navigationChild.textContent.toLowerCase().indexOf('prev') > -1) {
source.insertBefore(navigationChild, source.firstChild);
} else if (navigationChild.textContent.toLowerCase().indexOf('next') > -1) {
source.appendChild(navigationChild);
}
});
source.classList.add(
Array.from(navigationSource.classList).join()
)
navigationSource.parentNode.removeChild(navigationSource);
}
wrapWithNavigation();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
上述函数的 ES5 兼容替代方案如下:
function wrapWithNavigation() {
var source = document.querySelector('.thumbicon'),
navigationSource = document.querySelector('.flex-direction-nav');
Array.prototype.slice.call(navigationSource.children).forEach(
function(navigationChild) {
if (navigationChild.textContent.toLowerCase().indexOf('prev') > -1) {
source.insertBefore(navigationChild, source.firstChild);
} else if (navigationChild.textContent.toLowerCase().indexOf('next') > -1) {
source.appendChild(navigationChild);
}
});
source.classList.add(
Array.prototype.slice.call(navigationSource.classList).join()
)
navigationSource.parentNode.removeChild(navigationSource);
}
wrapWithNavigation();
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
和 jQuery 备选方案:
// again, using a named-function to allow for re-use:
function wrapWithNavigation() {
// finding the first, using eq(0), of any elements matching
// the supplied selectors:
let thumbicon = $('.thumbicon').eq(0),
navigationSource = $('.flex-direction-nav').eq(0);
// moving to the child elements of the navigationSource
// element, using each():
navigationSource.children().each(function() {
// using the same checks as above, using 'plain'
// JavaScript rather than jQuery to retrieve the
// text-content:
if (this.textContent.toLowerCase().indexOf('prev') > -1) {
// prepending the current child-element to the
// thumbicon element:
$(this).prependTo(thumbicon);
} else if (this.textContent.toLowerCase().indexOf('next') > -1) {
// appending the current element (if it matches the
// above test) to the thumicon element:
$(this).appendTo(thumbicon);
}
// returning to the previous selection (that of the
// navigationSource) using end(), and iterating over
// that selection - of one - using each():
}).end().each(function() {
// using addClass() to add the class-name of the
// current element to the thumbicon element:
thumbicon.addClass(this.className);
// and finally removing the navigationSource element
// using the remove() method:
}).remove();
}
wrapWithNavigation();
function wrapWithNavigation() {
let thumbicon = $('.thumbicon').eq(0),
navigationSource = $('.flex-direction-nav').eq(0);
navigationSource.children().each(function() {
if (this.textContent.toLowerCase().indexOf('prev') > -1) {
$(this).prependTo(thumbicon);
} else if (this.textContent.toLowerCase().indexOf('next') > -1) {
$(this).appendTo(thumbicon);
}
}).end().each(function() {
thumbicon.addClass(this.className);
}).remove();
}
wrapWithNavigation();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
我有 2 个 ul 和一组 list.I 想要在第一个列表中附加第二个列表的项目,如图所示
List 1
<ul class="thumbicon"> <!-- need to append the class 'flex-direction-nav' -->
<!-- append prev li -->
<li>item 1<li>
<li>item 2<li>
<li>item 3<li>
<!-- append next li -->
</ul>
List 2
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
我想要的
<ul class="thumbicon flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li>item 1<li>
<li>item 2<li>
<li>item 3<li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
在jquery中可以这样做吗?
$('ul:first-child').append('<li>...</li>');
你可以这样试试
首先将第一个 ul
中的 类 添加到第二个,然后将 li
添加到第一个 li
之后的第二个 ul
,最后删除第一个 ul
$('.flex-direction-nav')
.addClass($('ul.thumbicon')
.attr('class'))
.find('li:first')
.append($('ul.thumbicon').children())
$('ul:first').remove()
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
或者如果你想从第二个追加到第一个 div 你可以这样做。
$('.thumbicon')
.addClass($('ul.flex-direction-nav').attr('class'))
.prepend($('ul:eq(1) li:eq(0)'))
.append($('ul:eq(1) li:eq(0)'))
$('ul:eq(1)').remove()
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
Select 第一里使用 :first
and append it at the first of target ul using .prependTo()
and select second (that in this case is last) li using :last
and append it at the end of target ul using .appendTo()
.
$(".flex-direction-nav > li:first").prependTo(".thumbicon");
$(".flex-direction-nav > li:last").appendTo(".thumbicon");
$(".flex-direction-nav").remove();
$(".flex-direction-nav > li:first").prependTo(".thumbicon");
$(".flex-direction-nav > li:last").appendTo(".thumbicon");
$(".flex-direction-nav").remove();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
List 1
<ul class="thumbicon">
<li>item 1<li>
<li>item 2<li>
<li>item 3<li>
</ul>
List 2
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
你也可以在一行中完成这项工作jquery
$(".flex-direction-nav > li").prependTo(".thumbicon").last().appendTo(".thumbicon");
$(".flex-direction-nav").remove();
就像
一样简单$('.thumbicon').append($next).prepend($prev).addClass('flex-direction-nav');
var $next = $('.flex-nav-next');
var $prev = $('.flex-nav-prev');
$('.flex-direction-nav').remove(); // If you needed
$('.thumbicon').append($next).prepend($prev).addClass('flex-direction-nav');
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
虽然这很容易写在 jQuery 中,但我还想展示一个简单的 JavaScript 解决方案:
// using a named function, to enable re-use if required:
function wrapWithNavigation() {
// initialising variables with 'let' rather than 'var',
// this requires an ES6-compatible browser, but can be
// made ES5 compatible by replacing 'let' with 'var'.
// retrieving the first - if any - elements that match
// the supplied CSS selectors:
let source = document.querySelector('.thumbicon'),
navigationSource = document.querySelector('.flex-direction-nav');
// converting the NodeList of the navigationSource's child elements
// (note 'children' an not 'childNodes') into an Array, and
// iterating over that Array using Array.prototype.forEach() with
// an Arrow function (again, this requires ES6-compatibility):
Array.from(navigationSource.children).forEach(
// navigationChild is a reference to the current Array-element
// of the Array of child-elements over which we're iterating:
navigationChild => {
// if the text-content, converted to lowercase, of the
// element contains the string 'prev':
if (navigationChild.textContent.toLowerCase().indexOf('prev') > -1) {
// we then insert the child-element before the the first-child
// of the source element, using ParentNode.insertBefore():
source.insertBefore(navigationChild, source.firstChild);
// otherwise if the lowercase text-content contains the string
// 'next' we use Node.appendChild() to add the current child-
// element as the last-child of the source element:
} else if (navigationChild.textContent.toLowerCase().indexOf('next') > -1) {
source.appendChild(navigationChild);
}
});
// we use the Element.classList API to add class-names to
// the source element:
source.classList.add(
// we convert the classList (an Array-like list of
// class-names) of the navigationSource element into
// a String, using Array.prototype.join(), to create
// a comma-separated String of class-names to pass to
// the add() method of the Element.classList API:
Array.from(navigationSource.classList).join()
)
// we then find the parent-node of the navigationSource
// element, and remove the navigationSource element using
// parentNode.removeChild() (this wasn't mentioned in the
// question, and if you wish to retain the navigationSouce
// element this line can be omitted):
navigationSource.parentNode.removeChild(navigationSource);
}
wrapWithNavigation();
function wrapWithNavigation() {
let source = document.querySelector('.thumbicon'),
navigationSource = document.querySelector('.flex-direction-nav');
Array.from(navigationSource.children).forEach(
navigationChild => {
if (navigationChild.textContent.toLowerCase().indexOf('prev') > -1) {
source.insertBefore(navigationChild, source.firstChild);
} else if (navigationChild.textContent.toLowerCase().indexOf('next') > -1) {
source.appendChild(navigationChild);
}
});
source.classList.add(
Array.from(navigationSource.classList).join()
)
navigationSource.parentNode.removeChild(navigationSource);
}
wrapWithNavigation();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
上述函数的 ES5 兼容替代方案如下:
function wrapWithNavigation() {
var source = document.querySelector('.thumbicon'),
navigationSource = document.querySelector('.flex-direction-nav');
Array.prototype.slice.call(navigationSource.children).forEach(
function(navigationChild) {
if (navigationChild.textContent.toLowerCase().indexOf('prev') > -1) {
source.insertBefore(navigationChild, source.firstChild);
} else if (navigationChild.textContent.toLowerCase().indexOf('next') > -1) {
source.appendChild(navigationChild);
}
});
source.classList.add(
Array.prototype.slice.call(navigationSource.classList).join()
)
navigationSource.parentNode.removeChild(navigationSource);
}
wrapWithNavigation();
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>
和 jQuery 备选方案:
// again, using a named-function to allow for re-use:
function wrapWithNavigation() {
// finding the first, using eq(0), of any elements matching
// the supplied selectors:
let thumbicon = $('.thumbicon').eq(0),
navigationSource = $('.flex-direction-nav').eq(0);
// moving to the child elements of the navigationSource
// element, using each():
navigationSource.children().each(function() {
// using the same checks as above, using 'plain'
// JavaScript rather than jQuery to retrieve the
// text-content:
if (this.textContent.toLowerCase().indexOf('prev') > -1) {
// prepending the current child-element to the
// thumbicon element:
$(this).prependTo(thumbicon);
} else if (this.textContent.toLowerCase().indexOf('next') > -1) {
// appending the current element (if it matches the
// above test) to the thumicon element:
$(this).appendTo(thumbicon);
}
// returning to the previous selection (that of the
// navigationSource) using end(), and iterating over
// that selection - of one - using each():
}).end().each(function() {
// using addClass() to add the class-name of the
// current element to the thumbicon element:
thumbicon.addClass(this.className);
// and finally removing the navigationSource element
// using the remove() method:
}).remove();
}
wrapWithNavigation();
function wrapWithNavigation() {
let thumbicon = $('.thumbicon').eq(0),
navigationSource = $('.flex-direction-nav').eq(0);
navigationSource.children().each(function() {
if (this.textContent.toLowerCase().indexOf('prev') > -1) {
$(this).prependTo(thumbicon);
} else if (this.textContent.toLowerCase().indexOf('next') > -1) {
$(this).appendTo(thumbicon);
}
}).end().each(function() {
thumbicon.addClass(this.className);
}).remove();
}
wrapWithNavigation();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="thumbicon">
<li>item 1</li>
<li>item 2</li>
<li>item 3</li>
</ul>
<ul class="flex-direction-nav">
<li class="flex-nav-prev">
<a class="flex-prev" href="#">Previous</a>
</li>
<li class="flex-nav-next">
<a class="flex-next" href="#">Next</a>
</li>
</ul>