Cosa significa questa linea Magento JS JS?
-
12-12-2019 - |
Domanda
Questa riga di JavaScript è nel codice di base Magento in app / design / frontend / base / predefinita / modello / persistente / checkout / onepage / fatturazione.phtml:
$('billing-address-select') && billing.newAddress(!$('billing-address-select').value);
.
Ecco la linea in contesto:
<script type="text/javascript">
//<![CDATA[
var billing = new Billing('co-billing-form',
'<?php echo $this->getUrl('checkout/onepage/getAddress') ?>address/',
'<?php echo $this->getUrl('checkout/onepage/saveBilling') ?>');
var billingForm = new VarienForm('co-billing-form');
/*billingForm.setElementsRelation('billing:country_id',
'billing:region',
'<?php echo $this->getUrl('directory/json/childRegion') ?>',
'<?php echo $this->__('Select State/Province...') ?>');*/
$('billing-address-select') && billing.newAddress(!$('billing-address-select').value);
var billingRegionUpdater = new RegionUpdater('billing:country_id',
'billing:region',
'billing:region_id',
<?php echo $this->helper('directory')->getRegionJson() ?>,
undefined,
'billing:postcode');
if ($('onepage-guest-register-button')) {
Event.observe($('onepage-guest-register-button'), 'click', function(event) {
var billingRememberMe = $('co-billing-form').select('#remember-me-box');
if (billingRememberMe.length > 0) {
if ($('login:guest') && $('login:guest').checked) {
billingRememberMe[0].hide();
} else if ($('login:register') && ($('login:register').checked || $('login:register').type == 'hidden')) {
billingRememberMe[0].show();
}
}
});
}
//]]>
</script>
.
Sembra che stia confrontando due valori ma non facendo nulla con il confronto.Qual è lo scopo di esso?
Soluzione
Ho fatto qualche ricerca su questo.Pensavo che il && sia stato puramente logico "e", ma può anche essere usato come una scorciatoia per "se poi".
In questo caso, se $ ('fatturazione-indirizzo-select') è vera, la funzione newaddress (in opcheckout.js) sarà chiamata con "! $ ('fatturazione-indirizzo-select'). Valore" comeun argomento.È un modo strano per mostrare a livello di programmazione o nascondere il nuovo modulo di indirizzo su una pagina checkout.
Ecco una domanda di overflow stack dove questo è spiegato: https://stackoverflow.com/ Domande / 3859433 / An-spiegazione-of-shirthand-in-javascript
E una buona spiegazione di & vs &&: https://stackoverflow.com/questions/7310109/Quals-the-difference-tra-and-in-javascript