index.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453
  1. <template>
  2. <div class="weather-box">
  3. <template v-if="weatherKey == 'sunny'">
  4. <sunny></sunny>
  5. </template>
  6. <template v-if="weatherKey == 'ran'">
  7. <ran></ran>
  8. </template>
  9. <template v-if="weatherKey == 'snow'">
  10. <snow></snow>
  11. </template>
  12. <template v-if="weatherKey == 'clound'">
  13. <clound></clound>
  14. </template>
  15. <div class="weather">
  16. <div class="weather-top">
  17. <div class="logo">
  18. <img src="/skImage/weather/logo.png" alt="" />
  19. </div>
  20. <div class="weather-left">
  21. <div class="b-time">
  22. <span>北京时间</span>
  23. <span>{{ nowTime }}</span>
  24. </div>
  25. <div class="b-time">
  26. <span>首尔时间</span>
  27. <span>{{ sTime }}</span>
  28. </div>
  29. <div class="weather-detail">
  30. <div class="d-top">
  31. <img :src="'/skImage/weather/' + logonIcon" alt="" />
  32. <span>{{ temperature }} ℃</span>
  33. </div>
  34. <div class="d-bottom">
  35. <span>{{ nowDate }}</span>
  36. <span>{{ week }}</span>
  37. </div>
  38. </div>
  39. </div>
  40. </div>
  41. <div class="env-box">
  42. <div class="env-item env-box-bg">
  43. <div class="env-icon">
  44. <img
  45. :src="
  46. weatherKey == 'sunny'
  47. ? '/skImage/weather/温度.png'
  48. : '/skImage/weather/温度.png'
  49. "
  50. alt=""
  51. />
  52. <span>温度</span>
  53. </div>
  54. <div class="env-text">{{ envObj.Tdb }}</div>
  55. <div class="env-rate">℃</div>
  56. </div>
  57. <div class="env-item env-box-bg">
  58. <div class="env-icon">
  59. <img
  60. :src="
  61. weatherKey == 'sunny'
  62. ? '/skImage/weather/湿度.png'
  63. : '/skImage/weather/湿度.png'
  64. "
  65. alt=""
  66. />
  67. <span>湿度</span>
  68. </div>
  69. <div class="env-text">{{ envObj.RH }}</div>
  70. <div class="env-rate">%</div>
  71. </div>
  72. <div class="env-item env-box-bg">
  73. <div class="env-icon">
  74. <img
  75. :src="
  76. weatherKey == 'sunny'
  77. ? '/skImage/weather/甲醛.png'
  78. : '/skImage/weather/甲醛.png'
  79. "
  80. alt=""
  81. />
  82. <span>甲醛</span>
  83. </div>
  84. <div class="env-text">{{ envObj.HCHO }}</div>
  85. <div class="env-rate">mg/m³</div>
  86. </div>
  87. <div class="env-item env-box-bg">
  88. <div class="env-icon">
  89. <img
  90. :src="
  91. weatherKey == 'sunny'
  92. ? '/skImage/weather/pm.png'
  93. : '/skImage/weather/pm.png'
  94. "
  95. alt=""
  96. />
  97. <span>PM2.5</span>
  98. </div>
  99. <div class="env-text">{{ envObj.PM2d5 }}</div>
  100. <div class="env-rate">ug/m³</div>
  101. </div>
  102. </div>
  103. </div>
  104. </div>
  105. </template>
  106. <script lang="ts">
  107. import $ from "jquery";
  108. import { nextTick } from "vue";
  109. // import { getWeather } from "@/apis/envmonitor.ts";
  110. import {
  111. defineComponent,
  112. reactive,
  113. toRefs,
  114. onMounted,
  115. onBeforeUnmount,
  116. } from "vue";
  117. import ran from "./rain.vue"; // 雨
  118. import clound from "./cloud.vue"; // 云
  119. import snow from "./snow.vue"; // 雪
  120. import sunny from "./sunny.vue"; // 晴
  121. import { getWeather, queryEnvCurrent } from "@/apis/envmonitor";
  122. import { formatEnergyDate, getWeek } from "@/utils";
  123. import { useRouter } from "vue-router";
  124. export default defineComponent({
  125. components: {
  126. ran,
  127. clound,
  128. snow,
  129. sunny,
  130. },
  131. setup(props) {
  132. const router = useRouter();
  133. let weatherData: any = [
  134. {
  135. text: "云",
  136. type: "clound",
  137. logonIcon: "阴.png",
  138. },
  139. {
  140. text: "雨",
  141. type: "rain",
  142. logonIcon: "雨.png",
  143. },
  144. {
  145. text: "雪",
  146. type: "snow",
  147. logonIcon: "雪.png",
  148. },
  149. {
  150. text: "晴",
  151. type: "sunny",
  152. logonIcon: "晴.png",
  153. },
  154. ];
  155. let currentData: any = [];
  156. let envObj: any = {
  157. Tdb: "0", // 温度
  158. RH: "0", //湿度
  159. HCHO: "0", //甲醛
  160. PM2d5: "0",
  161. };
  162. let intevell: any = null;
  163. let timer: any = null;
  164. const proxyData = reactive({
  165. weatherData: weatherData,
  166. envObj: envObj,
  167. temperature: "",
  168. weatherKey: "sunny",
  169. logonIcon: "阴.png",
  170. currentData: currentData,
  171. nowTime: formatEnergyDate()[2],
  172. sTime: formatEnergyDate(2)[2],
  173. nowDate: formatEnergyDate()[0],
  174. intevell: intevell,
  175. week: getWeek(),
  176. // 设置现在时间
  177. setNowDate() {
  178. proxyData.intevell = setInterval(() => {
  179. let timeArr: any = formatEnergyDate();
  180. proxyData.nowTime = timeArr[2];
  181. proxyData.nowDate = timeArr[0];
  182. let timeArr1: any = formatEnergyDate(2);
  183. proxyData.sTime = timeArr1[2];
  184. proxyData.week = getWeek();
  185. }, 1000);
  186. },
  187. // 设置天气key的值
  188. setWeatherKey(content: any) {
  189. if (content.code <= 3) {
  190. proxyData.weatherKey = "sunny";
  191. proxyData.logonIcon = "晴.png";
  192. } else if (content.code >= 10 && content.code <= 19) {
  193. proxyData.weatherKey = "rain";
  194. proxyData.logonIcon = "雨.png";
  195. } else if (content.code >= 20 && content.code <= 25) {
  196. proxyData.weatherKey = "snow";
  197. proxyData.logonIcon = "雪.png";
  198. } else {
  199. if (content.code == "38") {
  200. proxyData.weatherKey = "sunny";
  201. proxyData.logonIcon = "晴.png";
  202. } else {
  203. proxyData.weatherKey = "clound";
  204. proxyData.logonIcon = "阴.png";
  205. }
  206. }
  207. },
  208. // 获取天气数据
  209. getWeatherData() {
  210. getWeather().then((res) => {
  211. let resResult: any = res;
  212. let content: any = resResult.content;
  213. proxyData.temperature = content.temperature;
  214. proxyData.setWeatherKey(content);
  215. });
  216. },
  217. timer: timer,
  218. setTimer(timeLen: any = 600000) {
  219. proxyData.timer = setInterval(() => {
  220. proxyData.setEnvData();
  221. proxyData.queryEnvCurrent();
  222. }, timeLen);
  223. },
  224. // 设置环境数据
  225. setEnvData() {
  226. proxyData.envObj = {
  227. Tdb: "0", // 温度
  228. RH: "0", //湿度
  229. HCHO: "0", //甲醛
  230. PM2d5: "0",
  231. };
  232. proxyData.currentData.map((item: any) => {
  233. if (item.code == "Tdb") {
  234. item.data = item.data ? item.data.toFixed(1) : "--";
  235. } else if (item.code == "RH") {
  236. item.data = item.data ? item.data.toFixed(0) : "--";
  237. } else if (item.code == "PM2d5") {
  238. item.data = item.data ? item.data.toFixed(0) : "--";
  239. } else {
  240. item.data = item.data ? item.data.toFixed(2) : "--";
  241. }
  242. proxyData.envObj[item.code] = item.data;
  243. });
  244. },
  245. // 获取环境数据
  246. queryEnvCurrent() {
  247. queryEnvCurrent()
  248. .then((res) => {
  249. let resResult: any = res;
  250. if (resResult.result == "success") {
  251. proxyData.currentData = resResult.data || [];
  252. } else {
  253. proxyData.currentData = [];
  254. }
  255. proxyData.setEnvData();
  256. })
  257. .catch((error: any) => {
  258. proxyData.currentData = [];
  259. });
  260. },
  261. changePage() {
  262. let times: any = setTimeout(() => {
  263. clearTimeout(times);
  264. router.push({ path: "/home" });
  265. }, 300000);
  266. },
  267. });
  268. onBeforeUnmount(() => {
  269. clearInterval(proxyData.intevell);
  270. clearInterval(proxyData.timer);
  271. });
  272. onMounted(() => {
  273. proxyData.setNowDate();
  274. // 获取天气数据
  275. proxyData.getWeatherData();
  276. // 获取环境数据
  277. proxyData.queryEnvCurrent();
  278. // proxyData.setTimer();
  279. });
  280. return {
  281. ...toRefs(proxyData),
  282. };
  283. },
  284. });
  285. </script>
  286. <style lang="scss" scoped>
  287. .weather-box {
  288. position: relative;
  289. width: 100%;
  290. height: 100%;
  291. .weather {
  292. position: absolute;
  293. box-sizing: border-box;
  294. padding: 80px 40px;
  295. padding-bottom: 0;
  296. width: 100%;
  297. left: 0;
  298. top: 0;
  299. }
  300. .env-box {
  301. display: flex;
  302. justify-content: space-between;
  303. width: 100%;
  304. margin-top: 7.8vh;
  305. .env-item {
  306. box-sizing: border-box;
  307. padding: 9.2vh 4.4vw 14vh 4.4vw;
  308. width: 24%;
  309. // opacity: 0.3;
  310. border-radius: 32px;
  311. background: rgba(255, 255, 255, 0.5);
  312. .env-icon {
  313. text-align: center;
  314. padding-bottom: 50px;
  315. img {
  316. width: 100px;
  317. display: inline-block;
  318. vertical-align: middle;
  319. }
  320. span {
  321. display: inline-block;
  322. margin-left: 20px;
  323. vertical-align: middle;
  324. font-size: 60px;
  325. font-weight: 500;
  326. letter-spacing: 0px;
  327. line-height: 60px;
  328. color: rgba(255, 255, 255, 1);
  329. }
  330. }
  331. .env-text {
  332. text-align: center;
  333. font-size: 130px;
  334. line-height: 160px;
  335. font-weight: 700;
  336. letter-spacing: 0px;
  337. color: rgba(255, 255, 255, 1);
  338. }
  339. .env-rate {
  340. padding-top: 80px;
  341. font-size: 60px;
  342. font-weight: 400;
  343. letter-spacing: 0px;
  344. line-height: 0px;
  345. color: rgba(255, 255, 255, 1);
  346. text-align: center;
  347. }
  348. &:nth-child(2) {
  349. img {
  350. width: 72px;
  351. }
  352. }
  353. &:nth-child(3) {
  354. img {
  355. width: 102px;
  356. }
  357. }
  358. &:nth-child(4) {
  359. img {
  360. width: 62px;
  361. }
  362. }
  363. }
  364. .env-box-bg {
  365. background: rgba(255, 255, 255, 0.1);
  366. }
  367. }
  368. .weather-top {
  369. display: flex;
  370. overflow: hidden;
  371. justify-content: space-between;
  372. .logo {
  373. width: 150px;
  374. img {
  375. width: 150px;
  376. }
  377. }
  378. .weather-left {
  379. // text-align: right;
  380. width: 72%;
  381. overflow: hidden;
  382. .b-time {
  383. display: inline-block;
  384. vertical-align: middle;
  385. margin-right: 180px;
  386. width: 270px;
  387. border-bottom: 1px solid rgba(255, 255, 255, 1);
  388. span {
  389. display: block;
  390. text-align: center;
  391. &:nth-child(1) {
  392. opacity: 1;
  393. padding-bottom: 20px;
  394. /** 文本1 */
  395. font-size: 18px;
  396. font-weight: 500;
  397. letter-spacing: 0px;
  398. color: rgba(255, 255, 255, 1);
  399. }
  400. &:nth-child(2) {
  401. font-size: 64px;
  402. font-weight: 700;
  403. letter-spacing: 0px;
  404. letter-spacing: 0px;
  405. color: rgba(255, 255, 255, 1);
  406. }
  407. }
  408. &:nth-child(2) {
  409. margin-right: 10px;
  410. }
  411. }
  412. }
  413. .weather-detail {
  414. // position: relative;
  415. // box-sizing: border-box;
  416. float: right;
  417. // padding-right: 73px;
  418. .d-top {
  419. text-align: right;
  420. padding-bottom: 12px;
  421. img {
  422. width: 73px;
  423. display: inline-block;
  424. vertical-align: middle;
  425. }
  426. span {
  427. display: inline-block;
  428. padding-left: 10px;
  429. font-size: 24px;
  430. font-weight: 400;
  431. color: rgba(242, 244, 246, 1);
  432. vertical-align: middle;
  433. }
  434. }
  435. .d-bottom {
  436. font-size: 24px;
  437. font-weight: 400;
  438. color: rgba(242, 244, 246, 1);
  439. span {
  440. &:nth-child(2) {
  441. padding-left: 10px;
  442. }
  443. }
  444. }
  445. }
  446. }
  447. }
  448. </style>