我们需要调整下拉列表的样式,以便在使用Google商家信息/地图自动填充API时显示自动填充位置建议。
有谁知道这是否可能?如果是这样,我想我们只需要知道CSS类名/ ID。
我在这里指的是一个屏幕抓取:
答案 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'
,然后返回“元素”标签,您现在就可以单独检查每个元素了。
这解决了失去焦点时总是关闭的问题。
答案 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)
);