您如何设置Google商家信息自动填充API下拉列表的样式?

时间:2011-10-25 18:13:14

标签: css google-maps autocomplete

我们需要调整下拉列表的样式,以便在使用Google商家信息/地图自动填充API时显示自动填充位置建议。

有谁知道这是否可能?如果是这样,我想我们只需要知道CSS类名/ ID。

我在这里指的是一个屏幕抓取:

Screengrab >

7 个答案:

答案 0 :(得分:111)

答案 1 :(得分:45)

如果您使用firebug(如对您的问题的评论中所述......),您会看到具有自动完成结果的容器是具有“pac-container”类的DIV,并且建议在其中作为DIV与班级“pac-item”。所以只用CSS风格。

答案 2 :(得分:14)

此CSS将允许下拉列表调整大小以适应结果的宽度:

.pac-container, .pac-item {
    width: inherit !important;
}

答案 3 :(得分:7)

我认为任何人都对我能够使用<div class="pac-container pac-logo" style="width: 557px; position: absolute; left: 66px; top: 106px; display: none;"> <div class="pac-item"> <span class="pac-icon pac-icon-marker"></span> <span class="pac-item-query"> <span>France</span> </span> </div> <div> 抓取以下内容的层次结构感兴趣:

{{1}}

答案 4 :(得分:3)

检查元素非常困难,因为它会在失去焦点时立即关闭。

虽然我们知道容器有.pac-container类且项目有.pac-item,但在进一步调查API后,我发现它在文档中嵌入了CSS样式。

这是最初的内容,因此请使用它来更改预定义的样式以满足您的需求。

.pac-container {
    background-color: #fff;
    position: absolute!important;
    z-index: 1000;
    border-radius: 2px;
    border-top: 1px solid #d9d9d9;
    font-family: Arial, sans-serif;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden
}

.pac-logo:after {
    content: "";
    padding: 1px 1px 1px 0;
    height: 16px;
    text-align: right;
    display: block;
    background-image: url(https://maps.gstatic.com/mapfiles/api-3/images/powered-by-google-on-white3.png);
    background-position: right;
    background-repeat: no-repeat;
    background-size: 120px 14px
}
.hdpi.pac-logo:after {
    background-image: url(https://maps.gstatic.com/mapfiles/api-3/images/powered-by-google-on-white3_hdpi.png)
}
.pac-item {
    cursor: default;
    padding: 0 4px;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    line-height: 30px;
    text-align: left;
    border-top: 1px solid #e6e6e6;
    font-size: 11px;
    color: #999
}
.pac-item:hover {
    background-color: #fafafa
}
.pac-item-selected,
.pac-item-selected:hover {
    background-color: #ebf2fe
}
.pac-matched {
    font-weight: 700
}
.pac-item-query {
    font-size: 13px;
    padding-right: 3px;
    color: #000
}
.pac-icon {
    width: 15px;
    height: 20px;
    margin-right: 7px;
    margin-top: 6px;
    display: inline-block;
    vertical-align: top;
    background-image: url(https://maps.gstatic.com/mapfiles/api-3/images/autocomplete-icons.png);
    background-size: 34px
}
.hdpi .pac-icon {
    background-image: url(https://maps.gstatic.com/mapfiles/api-3/images/autocomplete-icons_hdpi.png)
}
.pac-icon-search {
    background-position: -1px -1px
}
.pac-item-selected .pac-icon-search {
    background-position: -18px -1px
}
.pac-icon-marker {
    background-position: -1px -161px
}
.pac-item-selected .pac-icon-marker {
    background-position: -18px -161px
}
.pac-placeholder {
    color: gray
}

答案 5 :(得分:0)

要使框保持打开状态,以便更轻松地通过开发工具进行样式设置和检查,可以从JS控制台设置输入值,并且从开发工具进行检查时,容器将保持打开状态。

使用输入内容,只需在页面上的控制台中运行document.querySelector('.pac-target-input').value = 'CB',然后返回“元素”标签,您现在就可以单独检查每个元素了。

这解决了失去焦点时总是关闭的问题。

See this screenshot showing how it works

答案 6 :(得分:0)

如果您想创建自定义 html 和 css,则还可以使用 AutocompleteService 类,该类将提供 json 中的所有数据。

const service = new google.maps.places.AutocompleteService();
service.getQueryPredictions(
    { input: "provide location string here for search" },
    (suggestions) => console.log(suggestions)
);