Создание скретч-карты, но контейнер не будет отображаться в конце - PullRequest
0 голосов
/ 25 января 2019

У меня есть скретч-карта, которую я создаю с помощью jQuery и websanova / wScratchPad.

Блокнот работает хорошо, но он должен вызывать новый контейнер и кнопку один раз 50% отповерхность раскрывается.Это не.

Вот ссылка на сервер сбоя https://best -gambler.glitch.me /

Я искал решение онлайн, но не пришелс одним.

Вот файл HTML


  <html lang="en"><head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width">

  <link href="https://fonts.googleapis.com/css?family=Open+Sans:400,300,300italic,400italic,600,600italic,700italic,700" rel="stylesheet" type="text/css">

         <title>Scratch Card</title>
  <style type="text/css">
html {
  box-sizing: border-box;
}
*, *:before, *:after {
  box-sizing: inherit;
}
.scratchpad{
  width: 450px;
  height: 445px;
  border: solid 10px #FFFFFF;
  margin:0 auto;
}
body {
    background:#efefef;
}
.scratch-container {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  width:100%;
}
@media only screen and (max-width : 480px) {
  .scratchpad {width:400px;height:396px;}
  .scratch-container {width:400px !important;}
}

/* Custom, iPhone Retina */ 
@media only screen and (max-width : 320px) {
  .scratchpad {width:290px;height:287px;}
  .scratch-container {width:290px !important;}
}
.promo-container {
    background:#FFF;
    border-radius:5px;
    -moz-border-radius:5px;
    -webkit-border-radius:5px;
    width:450px;
    padding:20px;
    margin:0 auto;
    text-align:center;
    font-family:'Open Sans', Arial,Sans-serif;
    color:#333;
    font-size:16px;
    margin-top:20px;
}
.btn {
  background:#56CFD2;
  color:#FFF;
  padding:10px 25px;
  display:inline-block;
  margin-top:15px;
  text-decoration:none;
  font-weight:600;
  text-transform:uppercase;
  border-radius:3px;
  -moz-border-radius:3px;
  -webkit-border-radiuss:3px;
}
  </style>

</head>
<body>
<div class="scratch-container">
  <div id="promo" class="scratchpad"></div>
</div>
<div class="promo-container" style="display:none;">
  <div class="promo-code"></div>
  <a href="www.we-know-fun.com" target="_blank" class="btn">Register Now</a>
</div>


 <script src="//code.jquery.com/jquery-latest.min.js" type="text/javascript"></script>
  <script src="/wScratchPad.min.js" type="text/javascript"> </script>


      <script type="text/javascript">

var promoCode = '';
var bg1 = 'https://cdn.glitch.com/2c225b7b-6134-4f2b-9842-1d5d060d9cd4%2Farcher-slideGreen.png';
var bg2 = 'https://cdn.glitch.com/2c225b7b-6134-4f2b-9842-1d5d060d9cd4%2Farcher-slideGreen.png';
var bg3 = 'https://cdn.glitch.com/2c225b7b-6134-4f2b-9842-1d5d060d9cd4%2Farcher-slideGreen.png';
var bgArray= [ bg1, bg2, bg3 ],
selectBG = bgArray[Math.floor(Math.random() * bgArray.length)];
if (selectBG == bg1) {
    promoCode = 'SCRATCH400';
  } else if (selectBG == bg2) {
    promoCode = 'SCRATCH500';
  } if (selectBG == bg3) {
    var promoCode = '';
  }
$('#promo').wScratchPad({
    // the size of the eraser
    size        : 70,    
    // the randomized scratch image   
    bg:  selectBG,
    // give real-time updates
    realtime    : true, 
    // The overlay image
    fg: 'https://cdn.glitch.com/2c225b7b-6134-4f2b-9842-1d5d060d9cd4%2Foverlay.png',
    // The cursor (coin) image
    'cursor': 'url("https://cdn.glitch.com/2c225b7b-6134-4f2b-9842-1d5d060d9cd4%2Fcoin1.png") 5 5, default',

    scratchMove: function (percent) { 

        // Show the plain-text promo code and call-to-action when the scratch area is 50% scratched
       if ((percent > 50) && (promoCode != '')) {
         $('.promo-container').show();
          $('body').removeClass('not-selectable');
          $('.promo-code').html('Your code is: ' + promoCode);
        }
      }
 });
</script>


</body>
</html>

Что нужно сделать, это отобразить отдельный контейнер с текстом и кнопкой после того, как 50% или более поверхности «поцарапано»'прочь.

1 Ответ

0 голосов
/ 25 января 2019

Ваша функция scratchMove должна иметь дополнительный параметр e, который представляет событие перемещения мыши.Я думаю, что вы пропустили это из документации .Я только что проверил это локально, и это работает.

Кроме того, позаботьтесь о повторной инициализации переменной promoCode в этом операторе if-else: var promoCode = '';.Если бы изображения были другими, и промо-код был бы bg3 (что верно, поскольку bg1, bg2 и bg3 равны), это не сработало бы.

scratchMove: function (e, percent) { 
    console.log(percent);

   if ((percent > 50) && (promoCode != '')) {
      $('.promo-container').show();
      $('body').removeClass('not-selectable');
      $('.promo-code').html('Your code is: ' + promoCode);
   }
}

Однако вы можете проверить этосами и посмотрите результаты:)

Приветствия!

Позднее редактирование:

Вы сказали, что это не работает ... но это работает оченьну даже онлайн.Пожалуйста, посмотрите на этот jsfiddle .Извините за длинный js-код в конце тела, но у меня не было другого варианта включить пользовательскую библиотеку.Я хотел сделать jsfiddle здесь или использовать ссылку на библиотеку, чтобы показать вам, что она работает, но я не нашел CDN lib для scratchPad, и StackOverflow не позволяет включать файлы js из github.

В любом случае, я рекомендую обратить внимание на этот раздел:

if (selectBG == bg1) {
    promoCode = 'SCRATCH400';
  } else if (selectBG == bg2) {
    promoCode = 'SCRATCH500';
  } if (selectBG == bg3) {
    var promoCode = '';
  }

Это было изменено мной:

if (selectBG === bg1) {
  promoCode = 'SCRATCH400';
} else if (selectBG === bg2) {
  promoCode = 'SCRATCH500';
} else if (selectBG === bg3) {
  promoCode = '';
}

Я использовал 3 случайные картинки из Интернета.Также обратите внимание, что из-за условия if ((percent > 50) && (promoCode != '')), если сгенерированное изображение является третьим, ничего не появится.Зачем?Потому что вы устанавливаете promoCode в пустую строку в приведенном выше операторе if-else.Я не знаю, это ваше поведение или нет.

...