Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 23.09.2016, 18:11
Новичок на форуме
Отправить личное сообщение для bosic Посмотреть профиль Найти все сообщения от bosic
 
Регистрация: 23.09.2016
Сообщений: 3

Вывод данных в input
Помогите плиз. Есть виджет, после ввода города можно выбрать вариант доставки, после выбора он выводится ввиде текста, как можно сделать чтобы выбранная информация добавилась в input "info",а не в виде текста?


<!DOCTYPE html>
<html>
<head>
  <title>Оформление заказа</title>
  <!-- Следующие 2 строки нужно заменить кодом корзинного виджета из личного кабинета Яндекс.Доставки -->
<script type="text/javascript" src="https://api-maps.yandex.ru/2.1/?lang=ru-RU"></script>
 <script src="https://delivery.yandex-team.ru/widget/loader?resource_id=79&sid=3&key=6a75a675426b7768e629edb87255a099"></script>

  <!-- Создаем условный объект с данными о содержимом корзины (для примера) -->
  <script type="text/javascript">
    window.cart = {
      quantity: 3, //общее количество товаров
      weight: 2,
      cost: 1000
    }
  </script>

  <!-- Инициализация виджета -->
  <script type="text/javascript">
    ydwidget.ready(function(){
      ydwidget.initCartWidget({
        //получить указанный пользователем город
        'getCity': function () {
          var city = yd$('#city').val();
          if (city) {
            return {value: city};
          } else {
            return false;
          }
        },
        //id элемента-контейнера
        'el': 'ydwidget',
        //габариты 1 единицы усредненного товара
        'length': 10,
        'width': 10,
        'height': 10,
        //общее количество товаров в корзине
        'totalItemsQuantity': function () { return cart.quantity },
        //общий вес товаров в корзине
        'weight': function () { return cart.weight },
        //общая стоимость товаров в корзине
        'cost': function () { return cart.cost },
        //габариты и количество по каждому товару в корзине
        'itemsDimensions': function () {return [
          [10,15,10,2],
          [20,15,5,1]
        ]},
		//объявленная ценность заказа. Влияет на расчет стоимости в предлагаемых вариантах доставки, для записи поля в заказ данное поле так же нужно передать в объекте order (поле order_assessed_value)
		'assessed_value': cart.cost,
		//флаг отправки заказа через единый склад. Влияет на расчет стоимости в предлагаемых вариантах доставки, для записи поля в заказ данное поле так же нужно передать в объекте order (поле delivery_to_yd_warehouse).
		'to_yd_warehouse': 1,
        //обработка автоматически определенного города
        'setCity': function (city, region) { yd$('#city').val(region ? city + ', ' + region : city) },
        //обработка смены варианта доставки
        'onDeliveryChange': function (delivery) {
          //если выбран вариант доставки, выводим его описание и закрываем виджет, иначе произошел сброс варианта,
          //очищаем описание
          if (delivery) {
            yd$('#delivery_description').text(ydwidget.cartWidget.view.helper.getDeliveryDescription(delivery));
            ydwidget.cartWidget.close();
          } else {
            yd$('#delivery_description').text('')
          }
        },
        //завершение загрузки корзинного виджета
        'onLoad': function () {
          //при клике на радиокнопку, если это не радиокнопка "Яндекс.Доставка", сбрасываем выбранную доставку
          //в виджете
          yd$(document).on('click', 'input:radio[name="delivery"]', function () {
            if (yd$(this).not('#yd_delivery')) {
              ydwidget.cartWidget.setDeliveryVariant(null);
            }
          });
          //добавляем в форму отсутствующие поля "Улица", "Дом", "Индекс"
          var $streetField = yd$('<div><input type="text" id="street" placeholder="улица"></div>');
          var $houseField = yd$('<div><input type="text" id="house" placeholder="дом"></div>');
          var $indexField = yd$('<div><input type="text" id="index" placeholder="индекс"></div>');
          yd$('#city').after($streetField, $houseField, $indexField);
        },
        //снятие выбора с варианта доставки "Яндекс.Доставка" (настроенного в CMS)
        'unSelectYdVariant': function () { yd$('#yd_delivery').prop('checked', false) },
        //автодополнение
        'autocomplete': ['city', 'street', 'index'],
        'cityEl': '#city',
        'streetEl': '#street',
        'houseEl': '#house',
        'indexEl': '#index',
        //создавать заказ в cookie для его последующего создания в Яндекс.Доставке только если выбрана доставка Яндекса
        'createOrderFlag': function () { return yd$('#yd_delivery').is(':checked') },
        //необходимые для создания заказа поля
        //возможно указывать и другие поля, см. объект Order в документации
        'order': {
          //имя, фамилия, телефон, улица, дом, индекс
          'recipient_first_name': function () { return yd$('#name').val() },
          'recipient_last_name': function () { return yd$('#surname').val() },
          'recipient_phone': function () { return yd$('#phone').val() },
          'deliverypoint_street': function () { return yd$('#street').val() },
          'deliverypoint_house': function () { return yd$('#house').val() },
          'deliverypoint_index': function () { return yd$('#index').val() },
		  //объявленная ценность заказа
		  'order_assessed_value': cart.cost,
		  //флаг отправки заказа через единый склад.
		  'delivery_to_yd_warehouse': 1,
          //товарные позиции в заказе
          //возможно указывать и другие поля, см. объект OrderItem в документации
          'order_items': function () {
            var items = [];
            items.push({
              'orderitem_name': 'Товар 1',
              'orderitem_quantity': 2,
              'orderitem_cost': 100
            });
            items.push({
              'orderitem_name': 'Товар 2',
              'orderitem_quantity': 1,
              'orderitem_cost': 200
            });
            return items;
          }
        },
        //id элемента для вывода ошибок валидации. Вместо него можно указать параметр onValidationEnd, для кастомизации
        //вывода ошибок
        'errorsEl': 'yd_errors',
        //запустить сабмит формы, когда валидация успешно прошла и заказ создан в cookie,
        //либо если createOrderFlag вернул false
        'runOrderCreation': function () { yd$('form#order').submit() }
      })
    })
  </script>

</head>
<body>

<!-- элемент для отображения ошибок валидации -->
<div id="yd_errors"></div>

<form action="success.html" id="order">
  <fieldset style="float:left">
    <legend>Получатель</legend>
    <div><input type="text" name="name" placeholder="имя" id="name"></div>
    <div><input type="text" name="surname" placeholder="фамилия" id="surname"></div>
    <div><input type="text" name="phone" placeholder="телефон" id="phone"></div>
    <div><input type="text" name="city" placeholder="город" id="city"></div>

<div><input type="text" name="info" placeholder="информация о заказе" id="info"></div>

  </fieldset>
  <div style="float:left">
    <fieldset>
      <legend>Доставка</legend>
      <div><label><input type="radio" name="delivery">Доставка интернет-магазина</label></div>

      <!-- атрибут data-ydwidget-open обеспечивает открытие виджета при клике на элемент -->
      <div><label data-ydwidget-open><input type="radio" name="delivery" id="yd_delivery">Яндекс.Доставка</label></div>

      <p id="delivery_description"></p>
    </fieldset>
    <fieldset>
      <legend>Оплата</legend>
      <div><label><input type="radio" name="payment" id="payment_cash" checked="checked">Наличными при получении</label></div>
      <div><label><input type="radio" name="payment">Оплата Webmoney</label></div>
    </fieldset>

    <!-- Заменяем кнопку оформления заказа -->
    <!--<div><input type="submit" value="оформить заказ"></div>-->
    <div><input type="button" value="оформить заказ" data-ydwidget-createorder></div>

  </div>
</form>

<!-- Элемент-контейнер виджета. Класс yd-widget-modal обеспечивает отображение виджета в модальном окне -->
<div id="ydwidget" class="yd-widget-modal"></div>

</body>
</html>

Последний раз редактировалось bosic, 23.09.2016 в 18:15.
Ответить с цитированием
  #2 (permalink)  
Старый 23.09.2016, 18:39
Профессор
Отправить личное сообщение для Manyasha Посмотреть профиль Найти все сообщения от Manyasha
 
Регистрация: 21.09.2015
Сообщений: 196

bosic, так?
'onDeliveryChange': function (delivery) {
          //если выбран вариант доставки, выводим его описание и закрываем виджет, иначе произошел сброс варианта,
          //очищаем описание
          if (delivery) {
			var res = ydwidget.cartWidget.view.helper.getDeliveryDescription(delivery);
            yd$('#info').val(ydwidget.cartWidget.view.helper.getDeliveryDescription(delivery));
            ydwidget.cartWidget.close();
          } else {
            yd$('#info').val('')
          }
        },

вместо строчек 55-64
Ответить с цитированием
  #3 (permalink)  
Старый 23.09.2016, 18:44
Новичок на форуме
Отправить личное сообщение для bosic Посмотреть профиль Найти все сообщения от bosic
 
Регистрация: 23.09.2016
Сообщений: 3

Manyasha, спасибо! работает!
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Help Please. Вывод данных в input bosic Элементы интерфейса 0 23.09.2016 18:11
Скрипт копирования данных из select в input Arteeem Общие вопросы Javascript 6 04.08.2013 13:44
отправка данных из формы и вывод полученных данных sxe jQuery 2 21.05.2013 00:34
При добавлении DOCTYPE "плывут" размеры input type=text Demath (X)HTML/CSS 4 08.07.2012 19:27
Вывод данных в Друпал 6 из MySQL, небольшая работа torquemada Работа 1 22.05.2011 17:05