0

ダイアログでオートコンプリートを使用します。問題は、オートコンプリートが正しく表示されないことです。画像はそれを最もよく説明するので、これはどのように見えるかです:

ここに画像の説明を入力

ご覧のとおり、オートコンプリートは完全には表示されておらず、スクロールバーが右側に表示されています。私が達成したいのは、オートコンプリートがスクロールバーなしで完全に表示されることです。これは私が達成したいことです:

ここに画像の説明を入力

これはサンプル コードです (元のアプリケーション コードは複雑すぎるため、同じように動作するデモ アプリを作成しました)。

index.xhtml

<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:ice="http://www.icesoft.com/icefaces/component"
    xmlns:ace="http://www.icefaces.org/icefaces/components"
    xmlns:iscecore="http://www.icefaces.org/icefaces/core">
<h:head>
    <title>Insert title here</title>
    <ice:outputStyle href="./xmlhttp/css/xp/xp.css" rel="stylesheet"
        type="text/css" />
</h:head>
<h:body>
    <h:commandButton id="show" value="Show Dialog" onclick="sampleDialog.show();"/>
    <ace:dialog id="dialogId" header="Dialog example"
        widgetVar="sampleDialog" draggable="true" modal="true">
        <h:outputText value="dialog content"></h:outputText>
        <h:form id="autoCompleteForm">
            <ace:dialog id="dialogId" header="Dialog example"
                widgetVar="sampleDialog" draggable="true" modal="true">
                <h:outputText value="dialog content"></h:outputText>
            </ace:dialog>
            <ace:autoCompleteEntry id="componentId" rows="10" width="150"
                value="#{autoCompleteEntryBean.selectedText}"
                filterMatchMode="startsWith" label="Select city:">
                <f:selectItems value="#{autoCompleteEntryBean.cities}" />
            </ace:autoCompleteEntry>
        </h:form>
    </ace:dialog>
</h:body>
</html>

AutoCompleteEntryBean.java

package icefacesAutocompleteProblem;

import java.util.ArrayList;
import java.util.List;

import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import javax.faces.model.SelectItem;

@ManagedBean
@ViewScoped
public class AutoCompleteEntryBean {

    private String selectedText;
    private List<SelectItem> cities;

    @PostConstruct
    public void init() {
        cities = new ArrayList<SelectItem>();
        cities.add(new SelectItem("Warsaw"));
        cities.add(new SelectItem("Warsaw1"));
        cities.add(new SelectItem("Warsaw2"));
        cities.add(new SelectItem("Warsaw3"));
        cities.add(new SelectItem("Warsaw4"));
        cities.add(new SelectItem("Warsaw5"));
        cities.add(new SelectItem("Warsaw6"));
        cities.add(new SelectItem("Warsaw7"));
        cities.add(new SelectItem("Warsaw8"));
        cities.add(new SelectItem("Warsaw9"));
        cities.add(new SelectItem("Warsaw10"));
        cities.add(new SelectItem("Warsaw11"));
        cities.add(new SelectItem("Warsaw12"));
    }

    public String getSelectedText() {
        return selectedText;
    }

    public void setSelectedText(String selectedText) {
        this.selectedText = selectedText;
    }

    public List<SelectItem> getCities() {
        return cities;
    }

}
4

1 に答える 1

1

overflow: visible;ace:dialog とその内容 (div[id$='_main'])を設定することで問題が解決しました。

于 2013-10-14T07:38:30.580 に答える