system-clients 3.2.52 → 3.2.53-furuike

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (240) hide show
  1. package/.babelrc +5 -5
  2. package/.editorconfig +9 -9
  3. package/.eslintrc.js +16 -16
  4. package/CHANGELOG.md +51 -51
  5. package/README.md +36 -36
  6. package/SystemClient.iml +8 -8
  7. package/build/css-loaders.js +34 -34
  8. package/build/dev-client.js +8 -8
  9. package/build/example-server.js +80 -80
  10. package/build/release.sh +28 -28
  11. package/build/utils.js +71 -71
  12. package/build/webpack.base.conf.js +85 -85
  13. package/build/webpack.dev.conf.js +31 -31
  14. package/build/webpack.example.conf.js +49 -49
  15. package/build/webpack.prod.conf.js +60 -60
  16. package/build/webpack.test.conf.js +31 -31
  17. package/build.gradle +6 -6
  18. package/config/dev.env.js +6 -6
  19. package/config/index.js +38 -38
  20. package/config/prod.env.js +3 -3
  21. package/config/test.env.js +6 -6
  22. package/doc/Login.md +7 -7
  23. package/examples/LoginPage/App.vue +21 -21
  24. package/examples/LoginPage/index.html +11 -11
  25. package/examples/LoginPage/main.js +15 -15
  26. package/examples/ReadCard/App.vue +23 -23
  27. package/examples/ReadCard/index.html +11 -11
  28. package/examples/ReadCard/main.js +12 -12
  29. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  30. package/gradle/wrapper/gradle-wrapper.properties +5 -0
  31. package/index.html +21 -21
  32. package/package.json +1 -1
  33. package/release.bat +5 -5
  34. package/src/App.vue +24 -24
  35. package/src/LodopFuncs.js +123 -123
  36. package/src/assets/binding.svg +1 -1
  37. package/src/assets/unbind.svg +1 -1
  38. package/src/assets//345/205/254/345/221/212.svg +1 -1
  39. package/src/assets//347/207/203/346/260/224/347/274/264/350/264/271.eps +116 -116
  40. package/src/assets//350/201/224/347/263/273/346/210/221/344/273/254.svg +1 -1
  41. package/src/components/List.vue +51 -51
  42. package/src/components/Main.vue +785 -785
  43. package/src/components/TabButton.vue +201 -201
  44. package/src/components/Table.js +74 -74
  45. package/src/components/Tabs.vue +67 -67
  46. package/src/components/Util.js +343 -343
  47. package/src/components/addressManage/AddressCascadingMenu.vue +145 -145
  48. package/src/components/equipment/EquipmentManage.vue +65 -65
  49. package/src/components/equipment/PcAdd.vue +105 -105
  50. package/src/components/equipment/PcList.vue +119 -119
  51. package/src/components/equipment/PcManage.vue +60 -60
  52. package/src/components/equipment/PhoneAdd.vue +107 -107
  53. package/src/components/equipment/PhoneList.vue +112 -112
  54. package/src/components/equipment/PhoneManage.vue +60 -60
  55. package/src/components/equipment/PosAdd.vue +323 -323
  56. package/src/components/equipment/PosList.vue +294 -294
  57. package/src/components/equipment/PosManage.vue +138 -138
  58. package/src/components/equipment/PosManageBoth.vue +125 -125
  59. package/src/components/equipment/PosParamAdd.vue +236 -236
  60. package/src/components/equipment/PosParamList.vue +121 -121
  61. package/src/components/equipment/PosParamManage.vue +51 -51
  62. package/src/components/materialManage/materialData.vue +44 -44
  63. package/src/components/materialManage/materialList.vue +255 -255
  64. package/src/components/parammanage/ParamManage.vue +42 -42
  65. package/src/components/parammanage/ParamManages.vue +43 -43
  66. package/src/components/parammanage/ParamPage.vue +336 -336
  67. package/src/components/parammanage/ParamPages.vue +222 -222
  68. package/src/components/parammanage/SinglePage.vue +235 -235
  69. package/src/components/parammanage/SinglePages.vue +167 -167
  70. package/src/components/server/AddChangeMsg.vue +66 -66
  71. package/src/components/server/ChangeDeclare.vue +45 -45
  72. package/src/components/server/IconTree.vue +26 -26
  73. package/src/components/server/ImageVieweTest.vue +56 -56
  74. package/src/components/server/ImageViewer.vue +350 -350
  75. package/src/components/server/LeftTree.vue +111 -111
  76. package/src/components/server/LoadData.vue +55 -55
  77. package/src/components/server/Login.vue +568 -568
  78. package/src/components/server/LoginPage.vue +235 -235
  79. package/src/components/server/LoginView.vue +128 -128
  80. package/src/components/server/Menu.vue +188 -188
  81. package/src/components/server/ModifyPw.vue +111 -111
  82. package/src/components/server/PcdBuildingSelect.vue +241 -241
  83. package/src/components/server/ResSelect.vue +155 -155
  84. package/src/components/server/ResSelectGroup.vue +198 -198
  85. package/src/components/server/RightTree.vue +348 -348
  86. package/src/components/server/RoleSelector.vue +88 -88
  87. package/src/components/server/TestResSelect.vue +58 -58
  88. package/src/components/server/TestResSelectGroup.vue +388 -388
  89. package/src/components/server/TestRightTree.vue +42 -42
  90. package/src/filiale/chengtou/Login.vue +537 -537
  91. package/src/filiale/chengtou/system.js +5 -5
  92. package/src/filiale/dongguan/Login.vue +900 -900
  93. package/src/filiale/dongguan/Main.vue +715 -715
  94. package/src/filiale/dongguan/system.js +6 -6
  95. package/src/filiale/furuike/Login.vue +583 -583
  96. package/src/filiale/furuike/Main.vue +1 -13
  97. package/src/filiale/furuike/system.js +7 -7
  98. package/src/filiale/konggang/Login.vue +470 -470
  99. package/src/filiale/konggang/system.js +7 -7
  100. package/src/filiale/qianneng/Main.vue +816 -816
  101. package/src/filiale/qianneng/ModifyPw.vue +107 -107
  102. package/src/filiale/qianneng/system.js +8 -8
  103. package/src/filiale/rizhao/LeftTree.vue +111 -111
  104. package/src/filiale/rizhao/Login.vue +791 -791
  105. package/src/filiale/rizhao/Main.vue +611 -611
  106. package/src/filiale/rizhao/system.js +14 -14
  107. package/src/filiale/tongchuan/Login.vue +561 -561
  108. package/src/filiale/tongchuan/system.js +7 -7
  109. package/src/filiale/wenxi/Login.vue +535 -535
  110. package/src/filiale/wenxi/Main.vue +785 -785
  111. package/src/filiale/wenxi/system.js +10 -10
  112. package/src/filiale/yuchuan/Login.vue +889 -889
  113. package/src/filiale/yuchuan/Main.vue +773 -773
  114. package/src/filiale/yuchuan/system.js +10 -10
  115. package/src/filiale/zhoukou/Main.vue +807 -807
  116. package/src/filiale/zhoukou/system.js +6 -6
  117. package/src/index.js +7 -7
  118. package/src/plugins/EncryptUtil.js +53 -53
  119. package/src/plugins/GetLoginInfoService.js +521 -521
  120. package/src/plugins/HeatGetLoginInfoService.js +491 -491
  121. package/src/plugins/validation.js +15 -15
  122. package/src/project/ProjectPage.vue +24 -24
  123. package/src/project/State.js +17 -17
  124. package/src/stores/AppData.js +38 -38
  125. package/src/stores/HeatAppData.js +38 -38
  126. package/src/styles/fonts/glyphicons-halflings-regular.svg +288 -288
  127. package/src/styles/less/.csscomb.json +304 -304
  128. package/src/styles/less/.csslintrc +19 -19
  129. package/src/styles/less/alerts.less +73 -73
  130. package/src/styles/less/aofeng/animate.min.css +10 -10
  131. package/src/styles/less/aofeng/expandcss.less +569 -569
  132. package/src/styles/less/aofeng/login.less +367 -367
  133. package/src/styles/less/aofeng/standard.less +2507 -2507
  134. package/src/styles/less/aofeng/themeOne/BinaryTemplate.less +686 -686
  135. package/src/styles/less/aofeng/themeOne/loginStyle.less +1586 -1586
  136. package/src/styles/less/aofeng/themeOne/systemStyle.less +2650 -2650
  137. package/src/styles/less/aofeng/themeOne.less +17 -17
  138. package/src/styles/less/aofeng/themeTwo/newStyle1.less +415 -415
  139. package/src/styles/less/aofeng/themeTwo.less +3 -3
  140. package/src/styles/less/badges.less +66 -66
  141. package/src/styles/less/bootstrap.less +66 -66
  142. package/src/styles/less/breadcrumbs.less +26 -26
  143. package/src/styles/less/button-groups.less +247 -247
  144. package/src/styles/less/buttons.less +172 -172
  145. package/src/styles/less/carousel.less +269 -269
  146. package/src/styles/less/close.less +34 -34
  147. package/src/styles/less/code.less +69 -69
  148. package/src/styles/less/component-animations.less +33 -33
  149. package/src/styles/less/dropdowns.less +216 -216
  150. package/src/styles/less/fonts-list.less +25 -25
  151. package/src/styles/less/forms.less +626 -626
  152. package/src/styles/less/glyphicons.less +305 -305
  153. package/src/styles/less/grid.less +84 -84
  154. package/src/styles/less/input-groups.less +167 -167
  155. package/src/styles/less/jumbotron.less +52 -52
  156. package/src/styles/less/labels.less +64 -64
  157. package/src/styles/less/list-group.less +141 -141
  158. package/src/styles/less/manageStyle/manageChile.less +180 -180
  159. package/src/styles/less/manageStyle/manageStyle/manageChile.less +180 -180
  160. package/src/styles/less/manageStyle/manageStyle/manageStyle.less +1102 -1102
  161. package/src/styles/less/manageStyle/manageStyle/safeStyle.less +498 -498
  162. package/src/styles/less/manageStyle/manageStyle.less +1102 -1102
  163. package/src/styles/less/manageStyle/safeStyle.less +498 -498
  164. package/src/styles/less/media.less +66 -66
  165. package/src/styles/less/mixins/alerts.less +14 -14
  166. package/src/styles/less/mixins/background-variant.less +9 -9
  167. package/src/styles/less/mixins/border-radius.less +18 -18
  168. package/src/styles/less/mixins/buttons.less +69 -69
  169. package/src/styles/less/mixins/center-block.less +7 -7
  170. package/src/styles/less/mixins/clearfix.less +22 -22
  171. package/src/styles/less/mixins/forms.less +90 -90
  172. package/src/styles/less/mixins/gradients.less +59 -59
  173. package/src/styles/less/mixins/grid-framework.less +92 -92
  174. package/src/styles/less/mixins/grid.less +122 -122
  175. package/src/styles/less/mixins/hide-text.less +21 -21
  176. package/src/styles/less/mixins/image.less +33 -33
  177. package/src/styles/less/mixins/labels.less +12 -12
  178. package/src/styles/less/mixins/list-group.less +30 -30
  179. package/src/styles/less/mixins/nav-divider.less +10 -10
  180. package/src/styles/less/mixins/nav-vertical-align.less +9 -9
  181. package/src/styles/less/mixins/opacity.less +8 -8
  182. package/src/styles/less/mixins/pagination.less +24 -24
  183. package/src/styles/less/mixins/panels.less +24 -24
  184. package/src/styles/less/mixins/progress-bar.less +10 -10
  185. package/src/styles/less/mixins/reset-filter.less +8 -8
  186. package/src/styles/less/mixins/reset-text.less +18 -18
  187. package/src/styles/less/mixins/resize.less +6 -6
  188. package/src/styles/less/mixins/responsive-visibility.less +15 -15
  189. package/src/styles/less/mixins/size.less +10 -10
  190. package/src/styles/less/mixins/tab-focus.less +9 -9
  191. package/src/styles/less/mixins/table-row.less +44 -44
  192. package/src/styles/less/mixins/text-emphasis.less +9 -9
  193. package/src/styles/less/mixins/text-overflow.less +8 -8
  194. package/src/styles/less/mixins/vendor-prefixes.less +227 -227
  195. package/src/styles/less/mixins.less +40 -40
  196. package/src/styles/less/modals.less +151 -151
  197. package/src/styles/less/navbar.less +660 -660
  198. package/src/styles/less/navs.less +285 -285
  199. package/src/styles/less/normalize.less +424 -424
  200. package/src/styles/less/pager.less +76 -76
  201. package/src/styles/less/pagination.less +89 -89
  202. package/src/styles/less/panels.less +275 -275
  203. package/src/styles/less/popovers.less +131 -131
  204. package/src/styles/less/print.less +101 -101
  205. package/src/styles/less/progress-bars.less +87 -87
  206. package/src/styles/less/responsive-embed.less +35 -35
  207. package/src/styles/less/responsive-utilities.less +194 -194
  208. package/src/styles/less/scaffolding.less +161 -161
  209. package/src/styles/less/stand.less +207 -207
  210. package/src/styles/less/tables.less +312 -312
  211. package/src/styles/less/theme.less +291 -291
  212. package/src/styles/less/thumbnails.less +36 -36
  213. package/src/styles/less/tooltip.less +102 -102
  214. package/src/styles/less/type.less +316 -316
  215. package/src/styles/less/utilities.less +55 -55
  216. package/src/styles/less/variables.less +899 -899
  217. package/src/styles/less/wells.less +29 -29
  218. package/src/system.js +113 -113
  219. package/src/systemphone.js +11 -11
  220. package/src/util/Daiban.json +12 -12
  221. package/src/util/LdapHelper.js +75 -75
  222. package/test/e2e/custom-assertions/elementCount.js +26 -26
  223. package/test/e2e/nightwatch.conf.js +40 -40
  224. package/test/e2e/runner.js +30 -30
  225. package/test/e2e/specs/test.js +14 -14
  226. package/test/unit/.eslintrc +5 -5
  227. package/test/unit/index.js +13 -13
  228. package/test/unit/init.js +10 -10
  229. package/test/unit/karma.conf.js +49 -49
  230. package/test/unit/specs/base64.spec.js +5 -5
  231. package/test/unit/specs/components/parammanage/ParamPage.spec.js +20 -20
  232. package/test/unit/specs/components/parammanage/SinglePage.spec.js +20 -20
  233. package/test/unit/specs/components/server/LeftTree/App.vue +18 -18
  234. package/test/unit/specs/components/server/LeftTree/LeftTree.spec.js +22 -22
  235. package/test/unit/specs/components/server/LoadData.spec.js +24 -24
  236. package/test/unit/specs/components/server/Login.spec.js +61 -61
  237. package/test/unit/specs/components/server/RightTree.spec.js +50 -50
  238. package/test/unit/specs/plugins/GetLoginInfoService.spec.js +55 -55
  239. package/test/unit/test.html +76 -76
  240. package/yarn-error.log +6896 -6896
@@ -1,350 +1,350 @@
1
- <!--父组件调用时需要写一个按钮和两个方法 一个方法用来显示组件和传图片 另一个方法用来关闭此组件
2
- 具体用法参照 ImageVieweTest.vue
3
- -->
4
- <template>
5
- <div class="full-img" v-show="show">
6
- <div class="bor">
7
- <div class="magnify">
8
- <!-- 左边产品图片区域 -->
9
- <div class="left_contaner">
10
- <div class="middle_img" @mouseover="boxMouseOver" @mouseleave="boxMouseLeave">
11
- <!-- 产品图片 -->
12
- <img :src="middleImg" alt="">
13
- <!-- 阴影盒子 -->
14
- <div class="shade" @mouseover="shadeMouseOver" @mousemove="shadeMouseMove" ref="shade" v-show="isShade"></div>
15
- </div>
16
- <div>
17
- <!-- 缩略图容器 -->
18
- <div class="carousel">
19
- <!-- 缩略图展示盒子 -->
20
- <div class="show_box">
21
- <ul class="picture_container" ref="middlePicture">
22
- <li class="picture_item" @mouseover="tabPicture(item)" v-for="(index , item) in src" :key="index">
23
- <img :src="item.url" class="small_ima" alt="">
24
- </li>
25
- </ul>
26
- </div>
27
- </div>
28
- <button class="btn_" @click="clone">关闭</button>
29
- </div>
30
- </div>
31
- <!-- 右边放大区域 -->
32
- <div class="right_contanier" v-show="isBig">
33
- <img :src="middleImg" ref="bigImg" class="big_img" alt="">
34
- </div>
35
- </div>
36
- </div>
37
- </div>
38
- </template>
39
-
40
- <script>
41
- import $ from 'jquery'
42
- export default {
43
- title: '图片查看器',
44
- props: {
45
- src: {
46
- type: Array
47
- },
48
- show: {
49
- type: Boolean,
50
- default: false,
51
- },
52
- middleImgWidth: {
53
- default: 400,
54
- type: Number
55
- }, // 产品图片宽
56
- middleImgHeight: {
57
- default: 300,
58
- type: Number
59
- }, // 产品图片高
60
- thumbnailHeight: {
61
- default: 80,
62
- type: Number
63
- }, // 缩略图容器高度
64
- zoom: {
65
- default: 2, // 缩略比例,放大比例
66
- type: Number
67
- },
68
- width: {
69
- default: 80
70
- },
71
- height: {
72
- default: 60
73
- },
74
- alt: {
75
- default: '图片加载失败'
76
- },
77
- attach: {
78
- type: String,
79
- default: 'name'
80
- }
81
- },
82
- data () {
83
- return {
84
- middleImg: '', // 中图图片地址
85
- bigImg: '', // 大图图片地址
86
- isShade: false, // 控制阴影显示与否
87
- isBig: false, // 控制放大图显示与否
88
- initX: 0, // 初始clientX值
89
- initY: 0, // 初始clientY值
90
- leftX: 0, // 初始定位left
91
- topY: 0, // 初始定位top
92
- middleLeft: 0, // 当前放置小图盒子的定位left值,
93
- itemWidth: 80 // 缩略图每张的宽度
94
- }
95
- },
96
- ready () {
97
- this.$nextTick(() => {
98
- // 容器的高
99
- const imgWidth = this.middleImgHeight + this.thumbnailHeight + 120
100
- // const imgWidth = 400
101
- // 设置容器宽高
102
- $('.magnify').css({
103
- width: this.middleImgWidth,
104
- height: imgWidth
105
- })
106
- // 设置产品图宽高
107
- $('.middle_img').css({
108
- width: this.middleImgWidth,
109
- height: this.middleImgHeight
110
- })
111
- // 设置移动阴影图宽高
112
- $('.middle_img .shade').css({
113
- width: this.middleImgWidth/this.zoom,
114
- height: this.middleImgHeight/this.zoom
115
- })
116
- // 设置缩略图容器高
117
- $('.carousel').css({
118
- height: this.thumbnailHeight
119
- })
120
- // 设置每个缩略图宽
121
- $('.picture_item').css({
122
- width: this.itemWidth
123
- })
124
- // 设置放大后图片容器的宽高,left
125
- $('.right_contanier').css({
126
- left: this.middleImgWidth,
127
- width: imgWidth,
128
- height: imgWidth
129
- })
130
- // 设置放大图片的宽高(图片的放大倍数)
131
- $('.right_contanier .big_img').css({
132
- width: imgWidth * this.zoom,
133
- height: imgWidth * this.zoom
134
- })
135
- })
136
- },
137
- methods: {
138
- clone () {
139
- console.log('关闭')
140
- this.$emit('clone_f')
141
- },
142
- // 产品图片鼠标移入事件,显示阴影,显示大图
143
- boxMouseOver (e) {
144
- console.log(9999, e)
145
- e.preventDefault();
146
- e.stopPropagation();
147
- this.isShade = true
148
- this.isBig = true
149
- // 计算阴影的位置
150
- let x = e.offsetX - $('.shade').width()/2
151
- let y = e.offsetY - $('.shade').height()/2
152
- let maxLeft = $('.middle_img').width() - $('.shade').width()
153
- let maxTop = $('.middle_img').height() - $('.shade').height()
154
- x = x <= 0 ? 0 : x
155
- x = x >= maxLeft ? maxLeft : x
156
- y = y <= 0 ? 0 : y
157
- y = y >= maxTop ? maxTop : y
158
-
159
- $('.shade').css({
160
- left: x,
161
- top: y
162
- })
163
-
164
- },
165
- // 鼠标在阴影移动
166
- shadeMouseMove (e) {
167
- e.preventDefault();
168
- e.stopPropagation();
169
- // console.log($('.middle_img')[0].offsetParent.clientLeft)
170
- // console.log($('.middle_img')[0].offsetParent.offsetLeft)
171
- // 用页面x - 父盒子的offsetLeft - 父盒子的左边框宽度
172
- var x = this.getEventPage(e).pageX - $('.middle_img')[0].offsetParent.offsetLeft - $('.middle_img')[0].offsetParent.clientLeft;
173
- // var x = this.getEventPage(e).pageX - 312;
174
- // 用页面y - 父盒子的offsetTop - 父盒子的上边框宽度
175
- // console.log($('.middle_img')[0].offsetParent.offsetTop)
176
- var y = this.getEventPage(e).pageY - $('.middle_img')[0].offsetParent.offsetTop - $('.middle_img')[0].offsetParent.clientTop;
177
- // var y = this.getEventPage(e).pageY - 109 ;
178
-
179
- // 让阴影的坐标居中
180
- x -= $('.shade').width() / 2;
181
- y -= $('.shade').height() / 2;
182
-
183
- // 移动边界限制
184
- let maxLeft = $('.middle_img').width() - $('.shade').width()
185
- let maxTop = $('.middle_img').height() - $('.shade').height()
186
- x = x <= 0 ? 0 : x
187
- x = x >= maxLeft ? maxLeft : x
188
- y = y <= 0 ? 0 : y
189
- y = y >= maxTop ? maxTop : y
190
- // 重新赋值当前的定位值
191
- $('.shade').css({
192
- left: x,
193
- top: y
194
- })
195
- // 计算出实时的大图的定位,首先计算出比例
196
- // 比例为x:大图宽度/小图宽度 y: 大图高度/小图高度,将小图的定位乘以比例就是大图的定位
197
- const xRate = $('.big_img').width() / $('.middle_img').width()
198
- const yRate = $('.big_img').height() / $('.middle_img').height()
199
- $('.big_img').css({
200
- left: -x*xRate,
201
- top: -y*yRate
202
- })
203
- // console.log(e, x, y, xRate, yRate, 66677)
204
- },
205
- // 鼠标移入阴影,去除自定义事件
206
- shadeMouseOver (e) {
207
- e.preventDefault();
208
- e.stopPropagation();
209
- // console.log(88888, e)
210
- },
211
- // 图片移出隐藏阴影和大图
212
- boxMouseLeave (e) {
213
- this.isShade = false
214
- this.isBig = false
215
- },
216
- // 切换图片
217
- tabPicture (item) {
218
- this.middleImg = item.url
219
- },
220
- /**
221
- * 获取网页滚出去的距离(包括上面滚出去的部分和左边滚出去的部分)
222
- * @returns {{scrollTop: (Number|number), scrollLeft: (Number|number)}}
223
- */
224
- getPageScroll() {
225
- return {
226
- scrollTop: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0,
227
- scrollLeft: window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0
228
- }
229
- },
230
- /**
231
- * 获取事件对象点击的点,相对于文档左上角的坐标
232
- * @param e
233
- * @returns {{pageX: *, pageY: *}}
234
- */
235
- getEventPage(e) {
236
- return {
237
- pageX: e.clientX + this.getPageScroll().scrollLeft,
238
- pageY: e.clientY + this.getPageScroll().scrollTop
239
- }
240
- }
241
- },
242
- // 监听图片查看器是否打开 给产品图设默认值
243
- watch: {
244
- 'show'(val) {
245
- if (val) {
246
- this.middleImg = this.src[0].url
247
- }
248
- }
249
- }
250
- }
251
- </script>
252
-
253
- <style scoped>
254
- .full-img {
255
- position: fixed;
256
- top: 0;
257
- bottom: 0;
258
- left: 0;
259
- right: 0;
260
- z-index: 20;
261
- background: rgba(0,0,0,0.6);
262
- display: flex;
263
- overflow: auto;
264
- flex-direction: column;
265
- justify-content: center;
266
- align-items: center;
267
- color: #fff;
268
- }
269
- .bor {
270
- /*border: 2px solid #18D797;*/
271
- width: 904px;
272
- height: 504px;
273
- }
274
- .magnify {
275
- position: relative;
276
- }
277
- .small_ima {
278
- width: 100px;
279
- height: 80px;
280
- display: inline-block;
281
- }
282
- .left_contaner {
283
- width: 100%;
284
- height: 100%;
285
- }
286
- .left_contaner .middle_img {
287
- border: 1px solid #ccc;
288
- box-sizing: border-box;
289
- position: relative;
290
- }
291
- .left_contaner .shade {
292
- background-color: rgba( 135,206,235, .5);
293
- position: absolute;
294
- top: 0;
295
- left: 0; cursor: move;}
296
- .left_contaner .middle_img img {
297
- width: 100%;
298
- height: 100%;
299
- }
300
- .left_contaner .carousel {
301
- width: 100%;
302
- margin-top: 20px;
303
- display: -webkit-flex;
304
- }
305
- .left_contaner .carousel .show_box {
306
- flex: 1;
307
- overflow: hidden;
308
- position: relative;
309
- }
310
- .left_contaner .carousel .arrow {
311
- flex-basis: 25px;
312
- cursor: pointer;
313
- }
314
- .left_contaner .carousel .picture_container {
315
- position: absolute;
316
- overflow: hidden;
317
- top: 0;
318
- }
319
- .left_contaner .picture_container .picture_item {
320
- height: 100%;
321
- float: left;
322
- padding: 5px;
323
- box-sizing: border-box;
324
- }
325
- .left_contaner .picture_container .picture_item:hover {
326
- border: 2px solid #f2019f;
327
- }
328
- .right_contanier {
329
- overflow: hidden;
330
- position: absolute;
331
- top: 0;
332
- border: 1px solid #ccc;
333
- }
334
- .right_contanier .big_img {
335
- position: absolute;
336
- top: 0px;
337
- left: 0px;
338
- }
339
- .btn_ {
340
- background-color: #6aa6e2;
341
- position: absolute;
342
- bottom: 11px;
343
- left: 13px;
344
- width: 55px;
345
- height: 35px;
346
- border-radius: 5px;
347
- border: none;
348
- }
349
-
350
- </style>
1
+ <!--父组件调用时需要写一个按钮和两个方法 一个方法用来显示组件和传图片 另一个方法用来关闭此组件
2
+ 具体用法参照 ImageVieweTest.vue
3
+ -->
4
+ <template>
5
+ <div class="full-img" v-show="show">
6
+ <div class="bor">
7
+ <div class="magnify">
8
+ <!-- 左边产品图片区域 -->
9
+ <div class="left_contaner">
10
+ <div class="middle_img" @mouseover="boxMouseOver" @mouseleave="boxMouseLeave">
11
+ <!-- 产品图片 -->
12
+ <img :src="middleImg" alt="">
13
+ <!-- 阴影盒子 -->
14
+ <div class="shade" @mouseover="shadeMouseOver" @mousemove="shadeMouseMove" ref="shade" v-show="isShade"></div>
15
+ </div>
16
+ <div>
17
+ <!-- 缩略图容器 -->
18
+ <div class="carousel">
19
+ <!-- 缩略图展示盒子 -->
20
+ <div class="show_box">
21
+ <ul class="picture_container" ref="middlePicture">
22
+ <li class="picture_item" @mouseover="tabPicture(item)" v-for="(index , item) in src" :key="index">
23
+ <img :src="item.url" class="small_ima" alt="">
24
+ </li>
25
+ </ul>
26
+ </div>
27
+ </div>
28
+ <button class="btn_" @click="clone">关闭</button>
29
+ </div>
30
+ </div>
31
+ <!-- 右边放大区域 -->
32
+ <div class="right_contanier" v-show="isBig">
33
+ <img :src="middleImg" ref="bigImg" class="big_img" alt="">
34
+ </div>
35
+ </div>
36
+ </div>
37
+ </div>
38
+ </template>
39
+
40
+ <script>
41
+ import $ from 'jquery'
42
+ export default {
43
+ title: '图片查看器',
44
+ props: {
45
+ src: {
46
+ type: Array
47
+ },
48
+ show: {
49
+ type: Boolean,
50
+ default: false,
51
+ },
52
+ middleImgWidth: {
53
+ default: 400,
54
+ type: Number
55
+ }, // 产品图片宽
56
+ middleImgHeight: {
57
+ default: 300,
58
+ type: Number
59
+ }, // 产品图片高
60
+ thumbnailHeight: {
61
+ default: 80,
62
+ type: Number
63
+ }, // 缩略图容器高度
64
+ zoom: {
65
+ default: 2, // 缩略比例,放大比例
66
+ type: Number
67
+ },
68
+ width: {
69
+ default: 80
70
+ },
71
+ height: {
72
+ default: 60
73
+ },
74
+ alt: {
75
+ default: '图片加载失败'
76
+ },
77
+ attach: {
78
+ type: String,
79
+ default: 'name'
80
+ }
81
+ },
82
+ data () {
83
+ return {
84
+ middleImg: '', // 中图图片地址
85
+ bigImg: '', // 大图图片地址
86
+ isShade: false, // 控制阴影显示与否
87
+ isBig: false, // 控制放大图显示与否
88
+ initX: 0, // 初始clientX值
89
+ initY: 0, // 初始clientY值
90
+ leftX: 0, // 初始定位left
91
+ topY: 0, // 初始定位top
92
+ middleLeft: 0, // 当前放置小图盒子的定位left值,
93
+ itemWidth: 80 // 缩略图每张的宽度
94
+ }
95
+ },
96
+ ready () {
97
+ this.$nextTick(() => {
98
+ // 容器的高
99
+ const imgWidth = this.middleImgHeight + this.thumbnailHeight + 120
100
+ // const imgWidth = 400
101
+ // 设置容器宽高
102
+ $('.magnify').css({
103
+ width: this.middleImgWidth,
104
+ height: imgWidth
105
+ })
106
+ // 设置产品图宽高
107
+ $('.middle_img').css({
108
+ width: this.middleImgWidth,
109
+ height: this.middleImgHeight
110
+ })
111
+ // 设置移动阴影图宽高
112
+ $('.middle_img .shade').css({
113
+ width: this.middleImgWidth/this.zoom,
114
+ height: this.middleImgHeight/this.zoom
115
+ })
116
+ // 设置缩略图容器高
117
+ $('.carousel').css({
118
+ height: this.thumbnailHeight
119
+ })
120
+ // 设置每个缩略图宽
121
+ $('.picture_item').css({
122
+ width: this.itemWidth
123
+ })
124
+ // 设置放大后图片容器的宽高,left
125
+ $('.right_contanier').css({
126
+ left: this.middleImgWidth,
127
+ width: imgWidth,
128
+ height: imgWidth
129
+ })
130
+ // 设置放大图片的宽高(图片的放大倍数)
131
+ $('.right_contanier .big_img').css({
132
+ width: imgWidth * this.zoom,
133
+ height: imgWidth * this.zoom
134
+ })
135
+ })
136
+ },
137
+ methods: {
138
+ clone () {
139
+ console.log('关闭')
140
+ this.$emit('clone_f')
141
+ },
142
+ // 产品图片鼠标移入事件,显示阴影,显示大图
143
+ boxMouseOver (e) {
144
+ console.log(9999, e)
145
+ e.preventDefault();
146
+ e.stopPropagation();
147
+ this.isShade = true
148
+ this.isBig = true
149
+ // 计算阴影的位置
150
+ let x = e.offsetX - $('.shade').width()/2
151
+ let y = e.offsetY - $('.shade').height()/2
152
+ let maxLeft = $('.middle_img').width() - $('.shade').width()
153
+ let maxTop = $('.middle_img').height() - $('.shade').height()
154
+ x = x <= 0 ? 0 : x
155
+ x = x >= maxLeft ? maxLeft : x
156
+ y = y <= 0 ? 0 : y
157
+ y = y >= maxTop ? maxTop : y
158
+
159
+ $('.shade').css({
160
+ left: x,
161
+ top: y
162
+ })
163
+
164
+ },
165
+ // 鼠标在阴影移动
166
+ shadeMouseMove (e) {
167
+ e.preventDefault();
168
+ e.stopPropagation();
169
+ // console.log($('.middle_img')[0].offsetParent.clientLeft)
170
+ // console.log($('.middle_img')[0].offsetParent.offsetLeft)
171
+ // 用页面x - 父盒子的offsetLeft - 父盒子的左边框宽度
172
+ var x = this.getEventPage(e).pageX - $('.middle_img')[0].offsetParent.offsetLeft - $('.middle_img')[0].offsetParent.clientLeft;
173
+ // var x = this.getEventPage(e).pageX - 312;
174
+ // 用页面y - 父盒子的offsetTop - 父盒子的上边框宽度
175
+ // console.log($('.middle_img')[0].offsetParent.offsetTop)
176
+ var y = this.getEventPage(e).pageY - $('.middle_img')[0].offsetParent.offsetTop - $('.middle_img')[0].offsetParent.clientTop;
177
+ // var y = this.getEventPage(e).pageY - 109 ;
178
+
179
+ // 让阴影的坐标居中
180
+ x -= $('.shade').width() / 2;
181
+ y -= $('.shade').height() / 2;
182
+
183
+ // 移动边界限制
184
+ let maxLeft = $('.middle_img').width() - $('.shade').width()
185
+ let maxTop = $('.middle_img').height() - $('.shade').height()
186
+ x = x <= 0 ? 0 : x
187
+ x = x >= maxLeft ? maxLeft : x
188
+ y = y <= 0 ? 0 : y
189
+ y = y >= maxTop ? maxTop : y
190
+ // 重新赋值当前的定位值
191
+ $('.shade').css({
192
+ left: x,
193
+ top: y
194
+ })
195
+ // 计算出实时的大图的定位,首先计算出比例
196
+ // 比例为x:大图宽度/小图宽度 y: 大图高度/小图高度,将小图的定位乘以比例就是大图的定位
197
+ const xRate = $('.big_img').width() / $('.middle_img').width()
198
+ const yRate = $('.big_img').height() / $('.middle_img').height()
199
+ $('.big_img').css({
200
+ left: -x*xRate,
201
+ top: -y*yRate
202
+ })
203
+ // console.log(e, x, y, xRate, yRate, 66677)
204
+ },
205
+ // 鼠标移入阴影,去除自定义事件
206
+ shadeMouseOver (e) {
207
+ e.preventDefault();
208
+ e.stopPropagation();
209
+ // console.log(88888, e)
210
+ },
211
+ // 图片移出隐藏阴影和大图
212
+ boxMouseLeave (e) {
213
+ this.isShade = false
214
+ this.isBig = false
215
+ },
216
+ // 切换图片
217
+ tabPicture (item) {
218
+ this.middleImg = item.url
219
+ },
220
+ /**
221
+ * 获取网页滚出去的距离(包括上面滚出去的部分和左边滚出去的部分)
222
+ * @returns {{scrollTop: (Number|number), scrollLeft: (Number|number)}}
223
+ */
224
+ getPageScroll() {
225
+ return {
226
+ scrollTop: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0,
227
+ scrollLeft: window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0
228
+ }
229
+ },
230
+ /**
231
+ * 获取事件对象点击的点,相对于文档左上角的坐标
232
+ * @param e
233
+ * @returns {{pageX: *, pageY: *}}
234
+ */
235
+ getEventPage(e) {
236
+ return {
237
+ pageX: e.clientX + this.getPageScroll().scrollLeft,
238
+ pageY: e.clientY + this.getPageScroll().scrollTop
239
+ }
240
+ }
241
+ },
242
+ // 监听图片查看器是否打开 给产品图设默认值
243
+ watch: {
244
+ 'show'(val) {
245
+ if (val) {
246
+ this.middleImg = this.src[0].url
247
+ }
248
+ }
249
+ }
250
+ }
251
+ </script>
252
+
253
+ <style scoped>
254
+ .full-img {
255
+ position: fixed;
256
+ top: 0;
257
+ bottom: 0;
258
+ left: 0;
259
+ right: 0;
260
+ z-index: 20;
261
+ background: rgba(0,0,0,0.6);
262
+ display: flex;
263
+ overflow: auto;
264
+ flex-direction: column;
265
+ justify-content: center;
266
+ align-items: center;
267
+ color: #fff;
268
+ }
269
+ .bor {
270
+ /*border: 2px solid #18D797;*/
271
+ width: 904px;
272
+ height: 504px;
273
+ }
274
+ .magnify {
275
+ position: relative;
276
+ }
277
+ .small_ima {
278
+ width: 100px;
279
+ height: 80px;
280
+ display: inline-block;
281
+ }
282
+ .left_contaner {
283
+ width: 100%;
284
+ height: 100%;
285
+ }
286
+ .left_contaner .middle_img {
287
+ border: 1px solid #ccc;
288
+ box-sizing: border-box;
289
+ position: relative;
290
+ }
291
+ .left_contaner .shade {
292
+ background-color: rgba( 135,206,235, .5);
293
+ position: absolute;
294
+ top: 0;
295
+ left: 0; cursor: move;}
296
+ .left_contaner .middle_img img {
297
+ width: 100%;
298
+ height: 100%;
299
+ }
300
+ .left_contaner .carousel {
301
+ width: 100%;
302
+ margin-top: 20px;
303
+ display: -webkit-flex;
304
+ }
305
+ .left_contaner .carousel .show_box {
306
+ flex: 1;
307
+ overflow: hidden;
308
+ position: relative;
309
+ }
310
+ .left_contaner .carousel .arrow {
311
+ flex-basis: 25px;
312
+ cursor: pointer;
313
+ }
314
+ .left_contaner .carousel .picture_container {
315
+ position: absolute;
316
+ overflow: hidden;
317
+ top: 0;
318
+ }
319
+ .left_contaner .picture_container .picture_item {
320
+ height: 100%;
321
+ float: left;
322
+ padding: 5px;
323
+ box-sizing: border-box;
324
+ }
325
+ .left_contaner .picture_container .picture_item:hover {
326
+ border: 2px solid #f2019f;
327
+ }
328
+ .right_contanier {
329
+ overflow: hidden;
330
+ position: absolute;
331
+ top: 0;
332
+ border: 1px solid #ccc;
333
+ }
334
+ .right_contanier .big_img {
335
+ position: absolute;
336
+ top: 0px;
337
+ left: 0px;
338
+ }
339
+ .btn_ {
340
+ background-color: #6aa6e2;
341
+ position: absolute;
342
+ bottom: 11px;
343
+ left: 13px;
344
+ width: 55px;
345
+ height: 35px;
346
+ border-radius: 5px;
347
+ border: none;
348
+ }
349
+
350
+ </style>