NG显示刺激性图像位移

时间:2016-04-27 16:02:17

标签: javascript html angularjs boolean ng-show

自从我几周前写这篇文章以来,这个问题一直困扰着我的应用。基本上我有两个图像应该根据布尔值一次显示一个。使用ng-show指令,当我更新变量两次时,心脏图像被移位,好像另一个仍然存在并且不可见(我很可能确实如此)。

<i class="icon icon-accessory">
  <img class="padding-basic-right" src="img/love.svg" width="48px" ng-show="track.loved"/>
  <img class="padding-basic-right" src="img/skip.svg" width="48px" ng-show="!track.loved"/>
</i>

enter image description here

有没有解决这个/更好的解决方案?我现在可以和它一起生活,但为了清理它需要修复它。

2 个答案:

答案 0 :(得分:4)

<?php class ControllerPaymentWorldPay extends Controller { private $error = array(); public function index() { $this->load->language('payment/worldpay'); $this->document->setTitle($this->language->get('heading_title')); $this->load->model('setting/setting'); if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validate()) { $this->model_setting_setting->editSetting('worldpay', $this->request->post); $this->session->data['success'] = $this->language->get('text_success'); $this->response->redirect($this->url->link('extension/payment', 'token=' . $this->session->data['token'], 'SSL')); } $data['heading_title'] = $this->language->get('heading_title'); $data['text_edit'] = $this->language->get('text_edit'); $data['text_enabled'] = $this->language->get('text_enabled'); $data['text_disabled'] = $this->language->get('text_disabled'); $data['text_all_zones'] = $this->language->get('text_all_zones'); $data['text_yes'] = $this->language->get('text_yes'); $data['text_no'] = $this->language->get('text_no'); $data['text_successful'] = $this->language->get('text_successful'); $data['text_declined'] = $this->language->get('text_declined'); $data['text_off'] = $this->language->get('text_off'); $data['entry_merchant'] = $this->language->get('entry_merchant'); $data['entry_password'] = $this->language->get('entry_password'); $data['entry_callback'] = $this->language->get('entry_callback'); $data['entry_test'] = $this->language->get('entry_test'); $data['entry_total'] = $this->language->get('entry_total'); $data['entry_order_status'] = $this->language->get('entry_order_status'); $data['entry_geo_zone'] = $this->language->get('entry_geo_zone'); $data['entry_status'] = $this->language->get('entry_status'); $data['entry_sort_order'] = $this->language->get('entry_sort_order'); $data['help_password'] = $this->language->get('help_password'); $data['help_callback'] = $this->language->get('help_callback'); $data['help_total'] = $this->language->get('help_total'); $data['button_save'] = $this->language->get('button_save'); $data['button_cancel'] = $this->language->get('button_cancel'); if (isset($this->error['warning'])) { $data['error_warning'] = $this->error['warning']; } else { $data['error_warning'] = ''; } if (isset($this->error['merchant'])) { $data['error_merchant'] = $this->error['merchant']; } else { $data['error_merchant'] = ''; } if (isset($this->error['password'])) { $data['error_password'] = $this->error['password']; } else { $data['error_password'] = ''; } $data['breadcrumbs'] = array(); $data['breadcrumbs'][] = array( 'text' => $this->language->get('text_home'), 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], 'SSL') ); $data['breadcrumbs'][] = array( 'text' => $this->language->get('text_payment'), 'href' => $this->url->link('extension/payment', 'token=' . $this->session->data['token'], 'SSL') ); $data['breadcrumbs'][] = array( 'text' => $this->language->get('heading_title'), 'href' => $this->url->link('payment/worldpay', 'token=' . $this->session->data['token'], 'SSL') ); $data['action'] = $this->url->link('payment/worldpay', 'token=' . $this->session->data['token'], 'SSL'); $data['cancel'] = $this->url->link('extension/payment', 'token=' . $this->session->data['token'], 'SSL'); if (isset($this->request->post['worldpay_merchant'])) { $data['worldpay_merchant'] = $this->request->post['worldpay_merchant']; } else { $data['worldpay_merchant'] = $this->config->get('worldpay_merchant'); } if (isset($this->request->post['worldpay_password'])) { $data['worldpay_password'] = $this->request->post['worldpay_password']; } else { $data['worldpay_password'] = $this->config->get('worldpay_password'); } $data['callback'] = HTTP_CATALOG . 'index.php?route=payment/worldpay/callback'; if (isset($this->request->post['worldpay_test'])) { $data['worldpay_test'] = $this->request->post['worldpay_test']; } else { $data['worldpay_test'] = $this->config->get('worldpay_test'); } if (isset($this->request->post['worldpay_total'])) { $data['worldpay_total'] = $this->request->post['worldpay_total']; } else { $data['worldpay_total'] = $this->config->get('worldpay_total'); } if (isset($this->request->post['worldpay_order_status_id'])) { $data['worldpay_order_status_id'] = $this->request->post['worldpay_order_status_id']; } else { $data['worldpay_order_status_id'] = $this->config->get('worldpay_order_status_id'); } $this->load->model('localisation/order_status'); $data['order_statuses'] = $this->model_localisation_order_status->getOrderStatuses(); if (isset($this->request->post['worldpay_geo_zone_id'])) { $data['worldpay_geo_zone_id'] = $this->request->post['worldpay_geo_zone_id']; } else { $data['worldpay_geo_zone_id'] = $this->config->get('worldpay_geo_zone_id'); } $this->load->model('localisation/geo_zone'); $data['geo_zones'] = $this->model_localisation_geo_zone->getGeoZones(); if (isset($this->request->post['worldpay_status'])) { $data['worldpay_status'] = $this->request->post['worldpay_status']; } else { $data['worldpay_status'] = $this->config->get('worldpay_status'); } if (isset($this->request->post['worldpay_sort_order'])) { $data['worldpay_sort_order'] = $this->request->post['worldpay_sort_order']; } else { $data['worldpay_sort_order'] = $this->config->get('worldpay_sort_order'); } $data['header'] = $this->load->controller('common/header'); $data['column_left'] = $this->load->controller('common/column_left'); $data['footer'] = $this->load->controller('common/footer'); $this->response->setOutput($this->load->view('payment/worldpay.tpl', $data)); } protected function validate() { if (!$this->user->hasPermission('modify', 'payment/worldpay')) { $this->error['warning'] = $this->language->get('error_permission'); } if (!$this->request->post['worldpay_merchant']) { $this->error['merchant'] = $this->language->get('error_merchant'); } if (!$this->request->post['worldpay_password']) { $this->error['password'] = $this->language->get('error_password'); } return !$this->error; } } 与条件ng-src插值指令一起使用。

{{}}

其他替代方法是使用ng-src="{{ track.loved ? 'img/love.svg': 'img/skip.svg'}}" 代替ng-if

ng-show

答案 1 :(得分:1)

问题的一个可能原因是你的CSS覆盖了.ng-hide CSS类当ngShow解析为true时,Angular会添加到你的图像中。请尝试使用ng-if指令 - 这将导致未使用的img标记完全从DOM中删除。