⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 livesearchsample.java

📁 extjs + mysql + java
💻 JAVA
字号:
/*
 * GWT-Ext Widget Library
 * Copyright 2007 - 2008, GWT-Ext LLC., and individual contributors as indicated
 * by the @authors tag. See the copyright.txt in the distribution for a
 * full listing of individual contributors.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 3 of
 * the License, or (at your option) any later version.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */
 
package com.gwtext.sample.showcase2.client.combo;

import com.google.gwt.user.client.Window;
import com.gwtext.client.data.*;
import com.gwtext.client.util.Format;
import com.gwtext.client.widgets.Panel;
import com.gwtext.client.widgets.form.ComboBox;
import com.gwtext.client.widgets.form.FormPanel;
import com.gwtext.client.widgets.form.event.ComboBoxListenerAdapter;
import com.gwtext.sample.showcase2.client.ShowcasePanel;

/**
 * Styled ComboBox that gets data from a remote Json web service.
 */
public class LiveSearchSample extends ShowcasePanel {

    public String getSourceUrl() {
        return "source/combo/LiveSearchSample.java.html";
    }

    public Panel getViewPanel() {
		if (panel == null) {
			panel = new Panel();
			panel.setId("livesearch");

            //Use a ScriptTagProxy because you are getting data from a different domain using
            //a Json web service. If getting data from your own domain, then should use HttpProxy
            DataProxy dataProxy = new ScriptTagProxy("http://extjs.com/forum/topics-remote.php");

			RecordDef recordDef = new RecordDef(new FieldDef[]{
					new StringFieldDef("title", "topic_title"),
					new StringFieldDef("topicId", "topic_id"),
					new StringFieldDef("author", "author"),
					new DateFieldDef("lastPost", "post_time", "timestamp"),
					new StringFieldDef("excerpt", "post_text")
			});

			JsonReader reader = new JsonReader(recordDef);
			reader.setRoot("topics");
			reader.setTotalProperty("totalCount");
			reader.setId("post_id");

			final Store store = new Store(dataProxy, reader);
			store.load();

			final String resultTpl = "<div class=\"search-item\"><h3><span>{lastPost:date(\"M j, Y\")}<br />" +
					"by {author}</span>{title}</h3>{excerpt}</div>";

			ComboBox cb = new ComboBox();
			cb.setStore(store);
			cb.setDisplayField("title");
			cb.setTypeAhead(false);
			cb.setLoadingText("Searching...");
			cb.setWidth(440);
			cb.setPageSize(10);
			cb.setHideTrigger(true);
			cb.setTpl(resultTpl);
			cb.setMode(ComboBox.REMOTE);
			cb.setTitle("ExtJS Forums");
			cb.setHideLabel(true);
			cb.setItemSelector("div.search-item");

			cb.addListener(new ComboBoxListenerAdapter() {
				public void onSelect(ComboBox comboBox, Record record, int index) {
					String[] args = new String[]{record.getAsString("topicId"), record.getId()};
					String url = Format.format("http://extjs.com/forum/showthread.php?t={0}&p={1}", args);
					Window.open(url, "forum", "");
				}
			});

			Panel searchPanel = new Panel();
			searchPanel.setWidth(490);
            searchPanel.setHeight(150);
            searchPanel.setPaddings(20);
			searchPanel.setTitle("Search ExtJS Forums");
			searchPanel.setFrame(true);

            FormPanel form = new FormPanel();
            form.setBorder(false);
            form.add(cb);                        
            searchPanel.add(form);

			Panel instructionPanel = new Panel();
			instructionPanel.setBorder(false);
			instructionPanel.setPaddings(4,0,0,0);
			instructionPanel.setHtml("Live search requires a minimum of 4 characters.");
			searchPanel.add(instructionPanel);

			panel.add(searchPanel);
		}
		return panel;
	}

	public String getIntro() {
		return "<p>\n" +
				"    <b>Combo with Templates & Ajax</b>\n" +
				"    <p>This is a more advanced example that shows how you can combine paging, Template and a remote data store\n" +
				"    to create a \"live search\" feature.</p><p>Live search requires a minimum of 4 characters.</p>\n" +
                "   <p>This examples calls a Json Webservice to retreive data from the ExtJS forums and populate the Store backing the ComboBox.</p>"+
                "</p>";
	}

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -