element-ui 本地化使用教程详解


Posted in Javascript onOctober 28, 2019

起因:

用 element-ui 时,本人是没有安装其它环境,而是直接用链接引入,这个带来的问题是,每次打开网页都很慢,于是想本地化,但是发现只是下载两个引入的 js 和 css 是不够的,很多功能会无法使用,打开 DevTools 发现是还有别的资源本地没有。

element-ui 本地化使用教程详解

再次前往官网,找到下载页面,结果发现并没有给直接的下载链接。。没办法了,自己写个脚本来下载。最后成功离线化。

下载后在 html 中引入:

<!--<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">-->
<link rel="stylesheet" href="element-ui/lib/theme-chalk/index.css" rel="external nofollow" >

<!--<script src="https://unpkg.com/element-ui/lib/index.js"></script>-->
<script src="element-ui/lib/index.js"></script>

element-ui 本地化使用教程详解

下载脚本:

临时起意做的,代码里面可能会有些瑕疵,但是不影响使用,本人已经成功下载并使用。
路径可以自己更改,注意不要从 Windows 资源管理器复制,Linux 系统当我没说。

package com.ycr;

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;

public class Main {
 static String fileP = "C:\\Users\\YCR\\Desktop\\element-ui\\"; // 不要从资源管理器复制,有的字符会有问题,导致无法创建文件
 static String urlP = "https://unpkg.com/browse/element-ui@2.12.0/";
 static String urlF = "https://unpkg.com/element-ui@2.12.0/";
 public static void main(String[] args){
 try {
  GetPage("");
 } catch (Exception e) {
  e.printStackTrace();
 }
 }
 static void GetPage(String after) throws Exception {
 System.out.println(urlP + after);
 new File(fileP + after).mkdir();
 HttpURLConnection http = (HttpURLConnection) (new URL(urlP + after)).openConnection();
 http.setRequestMethod("GET");
 http.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3562.0 Safari/537.36");
 http.connect();
 if(http.getResponseCode() == 200) {
      InputStream inputStream = http.getInputStream();
      byte [] buffer = new byte[1024];
      ArrayList<byte []> byteList = new ArrayList<>();
      ArrayList<Integer> byteLength = new ArrayList<>();
      int length;
      int totalLength = 0;
      while( (length = inputStream.read(buffer)) != -1 ) {
       byteList.add(buffer);
       byteLength.add(length);
       totalLength += length;
       buffer = new byte[1024];
      }
      http.disconnect();
      byte [] all;
      all = new byte[totalLength];
      totalLength = 0;
      while(byteList.size() != 0) {
       System.arraycopy(byteList.get(0), 0, all, totalLength, byteLength.get(0));
       totalLength += byteLength.get(0);
       byteList.remove(0);
       byteLength.remove(0);
      }
      String content = new String(all, StandardCharsets.UTF_8);
      all = null;
      content = content.split("tbody")[1];
      String [] us = content.split("href=\"");
      for(int i = 1; i < us.length; i ++) {
       String href = us[i].split("\"", 2)[0];
       if(href.equals("../")) {
      continue;
     }
       if(href.charAt(href.length() - 1) == '/') {
       GetPage(after + href);
       } else {
       GetFile(after + href);
       }
      }
    } else {
  GetPage(after);
 }
 }
 static void GetFile(String url) throws Exception{
 System.out.println(url);
 HttpURLConnection http;
 http = (HttpURLConnection) (new URL(urlF + url)).openConnection();
 http.setRequestMethod("GET");
 http.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3562.0 Safari/537.36");
 http.connect();
 if(http.getResponseCode() == 200) {
      InputStream inputStream = http.getInputStream();
      byte [] buffer = new byte[1024];
      ArrayList<byte []> byteList = new ArrayList<>();
      ArrayList<Integer> byteLength = new ArrayList<>();
      int length;
      int totalLength = 0;
      while( (length = inputStream.read(buffer)) != -1 ) {
       byteList.add(buffer);
       byteLength.add(length);
       totalLength += length;
       buffer = new byte[1024];
      }
      http.disconnect();
      byte [] all;
      all = new byte[totalLength];
      totalLength = 0;
      while(byteList.size() != 0) {
       System.arraycopy(byteList.get(0), 0, all, totalLength, byteLength.get(0));
       totalLength += byteLength.get(0);
       byteList.remove(0);
       byteLength.remove(0);
      }
      File f = new File(fileP + url.replaceAll("/", "\\\\"));
      f.createNewFile();
      FileOutputStream fos = new FileOutputStream(f, false);
      fos.write(all);
      fos.flush();
      fos.close();
 } else {
  GetFile(url);
 }
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js解决弹窗问题实现班级跳转DIV示例
Jan 06 Javascript
JS正则表达式验证数字代码
Jan 28 Javascript
web前端设计师们常用的jQuery特效插件汇总
Dec 07 Javascript
详解jQuery移动页面开发中的ui-grid网格布局使用
Dec 03 Javascript
使用JS中的exec()方法构造正则表达式验证
Aug 01 Javascript
jQuery中用on绑定事件时需注意的事项
Mar 19 Javascript
vue-router 导航钩子的具体使用方法
Aug 31 Javascript
微信小程序使用map组件实现解析经纬度功能示例
Jan 22 Javascript
angular 服务随记小结
May 06 Javascript
webpack3升级到webpack4遇到问题总结
Sep 30 Javascript
JavaScript实现随机点名程序
Mar 25 Javascript
vue+高德地图实现地图搜索及点击定位操作
Sep 09 Javascript
vue 全局环境切换问题
Oct 27 #Javascript
vue 父组件通过v-model接收子组件的值的代码
Oct 27 #Javascript
解决包含在label标签下的checkbox在ie8及以下版本点击事件无效果兼容的问题
Oct 27 #Javascript
Vue-Cli项目优化操作的实现
Oct 27 #Javascript
layui table 复选框跳页后再回来保持原来选中的状态示例
Oct 26 #Javascript
Layui 解决表格异步调用后台分页的问题
Oct 26 #Javascript
Layui实现数据表格默认全部显示(不要分页)
Oct 26 #Javascript
You might like
php 多线程上下文中安全写文件实现代码
2009/12/28 PHP
php 5.3.5安装memcache注意事项小结
2011/04/12 PHP
php数组函数序列之array_flip() 将数组键名与值对调
2011/11/07 PHP
解析php中static,const与define的使用区别
2013/06/18 PHP
PHP获取php,mysql,apche的版本信息示例代码
2014/01/16 PHP
php安装ssh2扩展的方法【Linux平台】
2016/07/20 PHP
PHP实现大数(浮点数)取余的方法
2017/02/18 PHP
微信JSSDK分享功能图文实例详解
2019/04/08 PHP
13个绚丽的Jquery 界面设计网站推荐
2010/09/28 Javascript
node.js中的console用法总结
2014/12/15 Javascript
ExtJs动态生成treepanel的Json格式
2015/07/19 Javascript
javascript中eval和with用法实例总结
2015/11/30 Javascript
javascript实现拖放效果
2015/12/16 Javascript
JS 对象(Object)和字符串(String)互转方法
2016/05/20 Javascript
详解jQuery简单的表格应用
2016/12/16 Javascript
jQuery解析返回的xml和json方法详解
2017/01/05 Javascript
Vue中的ref作用详解(实现DOM的联动操作)
2017/08/21 Javascript
vue发送websocket请求和http post请求的实例代码
2019/07/11 Javascript
vue2.x 通过后端接口代理,获取qq音乐api的数据示例
2019/10/30 Javascript
Python监控主机是否存活并以邮件报警
2015/09/22 Python
Java编程迭代地删除文件夹及其下的所有文件实例
2018/02/10 Python
在python中以相同顺序shuffle两个list的方法
2018/12/13 Python
python计算Content-MD5并获取文件的Content-MD5值方式
2020/04/03 Python
基于FME使用Python过程图解
2020/05/13 Python
如何基于Python按行合并两个txt
2020/11/03 Python
HTML5上传文件显示进度的实现代码
2012/08/30 HTML / CSS
Zavvi荷兰:英国大型音像制品和图书游戏零售商
2018/03/22 全球购物
《美丽的公鸡》教学反思
2014/02/25 职场文书
国家奖学金获奖感言
2014/08/16 职场文书
研修心得体会
2014/09/04 职场文书
青年岗位能手事迹材料
2014/12/23 职场文书
贷款工作证明模板
2015/06/12 职场文书
2015年度优秀员工获奖感言
2015/07/31 职场文书
如何才能写好调研报告?
2019/07/03 职场文书
十大最帅动漫男主 碓冰拓海上榜,第一是《灌篮高手》男主角
2022/03/18 日漫
聊聊基于pytorch实现Resnet对本地数据集的训练问题
2022/03/25 Python