ボタンのクリックでスタイリングを前後に削除したいのですが、サイズを変更しようとすると、マップは画面全体にレンダリングされますが、背景はなく、その上にあったマーカーのみがレンダリングされます。
したがって、基本的には、スタイリングを削除してリスト要素を非表示にし、1 回のクリックでマップ要素のみを表示し、次のクリックでリストを再度表示し、マップのサイズを最初の状態に変更したいと考えています。
何か案は ?
**Updated**
**aura component**
<aura:component >
<aura:attribute name="map" type="Object"/>
<aura:attribute name="buttonstate" type="Boolean" default="false"/>
<div aura:id= "screen">
<div id="map" aura:id="mapSize" class="mapSize" style="position:relative;">
<lightning:button class="button" aura:id="buttonList" label="Button" onclick="{!c.handleClick}" />
</div>
</div>
<div aura:id="listDiv" class ="listDiv">
<c:List />
</div>
</div>
</aura:component>
**CSS**
.cAccountMap .mapSize{
width: 100%;
height: 80%;
}
.cAccountMap .mapTestSize{
height: 100%;
}
.THIS .listDiv{
height: 20%;
}
}
**Javascript**
handleClick : function(component,event,helper){
var buttonName = event.getSource();
var elements = document.getElementsByClassName("listDiv");
var buttonstate = component.get('v.buttonstate');
var cmpTarget = component.find('mapSize');
if(buttonstate==false){
buttonName.set('v.label', 'LALA');
elements[0].style.display = 'none';
$A.util.removeClass(cmpTarget, 'mapSize');
$A.util.addClass(cmpTarget, 'mapTestSize');
}else{
buttonName.set('v.label', 'gogo');
elements[0].style.display = '';
$A.util.addClass(cmpTarget, 'mapSize');
$A.util.removeClass(cmpTarget, 'mapTestSize');
}
component.set('v.buttonstate', !buttonstate);
}