夏邑12345_前端

feedback-page.js 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. (function (mui, window, document, undefined) {
  2. mui.init();
  3. var get = function (id) {
  4. return document.getElementById(id);
  5. };
  6. var qsa = function (sel) {
  7. return [].slice.call(document.querySelectorAll(sel));
  8. };
  9. var ui = {
  10. question: get('question'),
  11. contact: get('contact'),
  12. imageList: get('image-list'),
  13. submit: get('submit')
  14. };
  15. ui.clearForm = function () {
  16. ui.question.value = '';
  17. ui.contact.value = '';
  18. ui.imageList.innerHTML = '';
  19. ui.newPlaceholder();
  20. };
  21. ui.getFileInputArray = function () {
  22. return [].slice.call(ui.imageList.querySelectorAll('input[type="file"]'));
  23. };
  24. ui.getFileInputIdArray = function () {
  25. var fileInputArray = ui.getFileInputArray();
  26. var idArray = [];
  27. fileInputArray.forEach(function (fileInput) {
  28. if (fileInput.value != '') {
  29. idArray.push(fileInput.getAttribute('id'));
  30. }
  31. });
  32. return idArray;
  33. };
  34. var imageIndexIdNum = 0;
  35. ui.newPlaceholder = function () {
  36. var fileInputArray = ui.getFileInputArray();
  37. if (fileInputArray &&
  38. fileInputArray.length > 0 &&
  39. fileInputArray[fileInputArray.length - 1].parentNode.classList.contains('space')) {
  40. return;
  41. }
  42. imageIndexIdNum++;
  43. var placeholder = document.createElement('div');
  44. placeholder.setAttribute('class', 'image-item space');
  45. var closeButton = document.createElement('div');
  46. closeButton.setAttribute('class', 'image-close');
  47. closeButton.innerHTML = 'X';
  48. closeButton.addEventListener('click', function (event) {
  49. event.stopPropagation();
  50. event.cancelBubble = true;
  51. setTimeout(function () {
  52. ui.imageList.removeChild(placeholder);
  53. }, 0);
  54. return false;
  55. }, false);
  56. var fileInput = document.createElement('input');
  57. fileInput.setAttribute('type', 'file');
  58. //multiple="true"
  59. fileInput.setAttribute('class', 'image-box');
  60. fileInput.setAttribute('accept', 'image/*');
  61. //fileInput.setAttribute('accept', 'image/*');
  62. //fileInput.setAttribute('accept', 'image/gif,image/jpeg,image/png,image/jpg');
  63. fileInput.accept="image/*";
  64. fileInput.setAttribute('id', 'image-' + imageIndexIdNum);
  65. fileInput.addEventListener('change', function (event) {
  66. var file = fileInput.files[0];
  67. var lengh = document.getElementsByClassName("image-item").length;
  68. if (lengh < 6) {
  69. if (file) {
  70. //var filename = $("#image-" + imageIndexIdNum).val();
  71. //fileName = filename.split("\\")[2];
  72. var fileName = file.name;//"";//
  73. //alert(fileName);
  74. var reader = new FileReader();
  75. reader.onload = function () {
  76. //处理 android 4.1 兼容问题
  77. var base64 = reader.result.split(',')[1];
  78. var dataUrl = 'data:image/png;base64,' + base64;
  79. placeholder.style.backgroundImage = 'url(' + dataUrl + ')';
  80. $.ajax({
  81. type: "post",
  82. url: huayi.config.callcenter_url + '/Web/Upload64',
  83. async: true,
  84. dataType: 'json',
  85. data: {
  86. dataurl: dataUrl,
  87. filename: fileName
  88. },
  89. success: function (data) {
  90. if (data.state == "success") {
  91. fileInput.setAttribute('indexs', data.data.F_FileId);
  92. mui.toast('上传成功');
  93. }
  94. }
  95. });
  96. }
  97. reader.readAsDataURL(file);
  98. placeholder.classList.remove('space');
  99. ui.newPlaceholder();
  100. }
  101. } else {
  102. mui.toast('最多上传五张');
  103. }
  104. }, false);
  105. placeholder.appendChild(closeButton);
  106. placeholder.appendChild(fileInput);
  107. ui.imageList.appendChild(placeholder);
  108. };
  109. ui.newPlaceholder();
  110. })(mui, window, document, undefined);