Home Web Front-end HTML Tutorial 如何调整wicket的PagingNavigator的html输出_html/css_WEB-ITnose

如何调整wicket的PagingNavigator的html输出_html/css_WEB-ITnose

Jun 21, 2016 am 09:18 AM

这是默认模板:

<wicket:panel>	<a wicket:id="first" class="first"><<</a>	<a wicket:id="prev" class="prev"><</a>	<span wicket:id="navigation" class="goto">		<a wicket:id="pageLink" href="#"><span wicket:id="pageNumber">5</span></a>	</span>	<a wicket:id="next" class="next">></a>	<a wicket:id="last" class="last">>></a></wicket:panel>
Copy after login

当然最外围的tag由该组件的模板决定。比如外围用div:

<div wicket:id="mypaginator"></div>
Copy after login

现在假设需要purecss样式的pagingNavigator,它的html如下:

<ul class="pure-paginator">    <li><a class="pure-button prev" href="#">&#171;</a></li>    <li><a class="pure-button" href="#">1</a></li>    <li><a class="pure-button pure-button-active" href="#">2</a></li>    <li><a class="pure-button" href="#">3</a></li>    <li><a class="pure-button" href="#">4</a></li>    <li><a class="pure-button" href="#">5</a></li>    <li><a class="pure-button next" href="#">&#187;</a></li></ul>
Copy after login

可见两者的差别还是不少。让我们看看可能的方法:

1、新建一个类,继承PagingNavigator。

比如类名称是PagingNavigator,然后建立对应的模板文件PagingNavigator.html,内容如下:

<ul class="pure-paginator">    <li><a wicket:id="first" class="pure-button first" href="#">&#171;</a></li>    <li><a wicket:id="prev" class="pure-button prev" href="#">&#171;</a></li>    <li wicket:id="navigation"><a wicket:id="pageLink" class="pure-button" href="#"><wicket:container wicket:id="pageNumber"></wicket:container></a></li>    <li><a wicket:id="next" class="pure-button next" href="#">&#187;</a></li>    <li><a wicket:id="last" class="pure-button last" href="#">&#187;</a></li></ul>
Copy after login

这样子画出来的PagingNavigator的就是purecss样式的。但是还需要完善,当前页的样式,没有最后一页的时候按钮应该disabled。也就是说根据当前页的情况需要添加pure-button-disabled,或者pure-button-active样式。

为了达成这个功能,我们需要更深的探究PagingNavigator类,看看哪里可以实现这个功能。

对照上面的模板,其中wicket:id="navigation"对应的是PagingNavigation组件,其中有一个方法是:

@Override	protected void populateItem(final LoopItem loopItem)	{		// Get the index of page this link shall point to		final long pageIndex = getStartIndex() + loopItem.getIndex();		// Add a page link pointing to the page		final AbstractLink link = newPagingNavigationLink("pageLink", pageable, pageIndex);		link.add(new TitleAppender(pageIndex));		loopItem.add(link);		// Add a page number label to the list which is enclosed by the link		String label = "";		if (labelProvider != null)		{			label = labelProvider.getPageLabel(pageIndex);		}		else		{			label = String.valueOf(pageIndex + 1);		}		link.add(new Label("pageNumber", label));	}
Copy after login

其中TitleAppender用来添加link的title属性,这样鼠标移到上面的时候就会提示,比如goto 2 page等等。接下来是label,就是pageNumber对应的组件。

可以通过复写这个方法,根据情况对label进行修饰(AttributeModifier),最终达到需要的效果。


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Have Crossplay?
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What is the purpose of the <progress> element? What is the purpose of the <progress> element? Mar 21, 2025 pm 12:34 PM

The article discusses the HTML &lt;progress&gt; element, its purpose, styling, and differences from the &lt;meter&gt; element. The main focus is on using &lt;progress&gt; for task completion and &lt;meter&gt; for stati

What is the purpose of the <datalist> element? What is the purpose of the <datalist> element? Mar 21, 2025 pm 12:33 PM

The article discusses the HTML &lt;datalist&gt; element, which enhances forms by providing autocomplete suggestions, improving user experience and reducing errors.Character count: 159

What is the purpose of the <meter> element? What is the purpose of the <meter> element? Mar 21, 2025 pm 12:35 PM

The article discusses the HTML &lt;meter&gt; element, used for displaying scalar or fractional values within a range, and its common applications in web development. It differentiates &lt;meter&gt; from &lt;progress&gt; and ex

What is the viewport meta tag? Why is it important for responsive design? What is the viewport meta tag? Why is it important for responsive design? Mar 20, 2025 pm 05:56 PM

The article discusses the viewport meta tag, essential for responsive web design on mobile devices. It explains how proper use ensures optimal content scaling and user interaction, while misuse can lead to design and accessibility issues.

Is HTML easy to learn for beginners? Is HTML easy to learn for beginners? Apr 07, 2025 am 12:11 AM

HTML is suitable for beginners because it is simple and easy to learn and can quickly see results. 1) The learning curve of HTML is smooth and easy to get started. 2) Just master the basic tags to start creating web pages. 3) High flexibility and can be used in combination with CSS and JavaScript. 4) Rich learning resources and modern tools support the learning process.

What is the purpose of the <iframe> tag? What are the security considerations when using it? What is the purpose of the <iframe> tag? What are the security considerations when using it? Mar 20, 2025 pm 06:05 PM

The article discusses the &lt;iframe&gt; tag's purpose in embedding external content into webpages, its common uses, security risks, and alternatives like object tags and APIs.

The Roles of HTML, CSS, and JavaScript: Core Responsibilities The Roles of HTML, CSS, and JavaScript: Core Responsibilities Apr 08, 2025 pm 07:05 PM

HTML defines the web structure, CSS is responsible for style and layout, and JavaScript gives dynamic interaction. The three perform their duties in web development and jointly build a colorful website.

What is an example of a starting tag in HTML? What is an example of a starting tag in HTML? Apr 06, 2025 am 12:04 AM

AnexampleofastartingtaginHTMLis,whichbeginsaparagraph.StartingtagsareessentialinHTMLastheyinitiateelements,definetheirtypes,andarecrucialforstructuringwebpagesandconstructingtheDOM.

See all articles