当前位置: 首页 > news >正文

网页和网站做哪个好用网页设计模板素材图片

网页和网站做哪个好用,网页设计模板素材图片,品牌建设的步骤是( ),媒体邀约文章目录 一、构建方法1、api/request.js2、api/requestHandler.js3、api/index.js 二、测试方法1、api/axios.js2、main.js3、app.vue4、vue.config.js5、index.html 三、打包1、配置package.json2、生成库包3、配置发布信息4、发布 四、使用1、安装2、使用 五、维护1、维护和…

文章目录

      • 一、构建方法
        • 1、api/request.js
        • 2、api/requestHandler.js
        • 3、api/index.js
      • 二、测试方法
        • 1、api/axios.js
        • 2、main.js
        • 3、app.vue
        • 4、vue.config.js
        • 5、index.html
      • 三、打包
        • 1、配置package.json
        • 2、生成库包
        • 3、配置发布信息
        • 4、发布
      • 四、使用
        • 1、安装
        • 2、使用
      • 五、维护
        • 1、维护和更新
        • 2、注意事项

一、构建方法

  • 确定工具库的需求和功能:在开始构建工具库之前,你需要明确你的工具库需要包含哪些方法及工具,以及这些工具或方法应该具备哪些功能。这有助于你更好地规划你的开发工作。

  • 编写工具代码:使用你熟悉的前端框架(如React、Vue等)编写工具代码。确保你的代码具有良好的可读性和可维护性,并遵循相关的编码规范。

  • 创建工具库的结构:为了组织和管理你的组件,你需要创建一个清晰的目录结构。这可以包括组件的源代码、样式文件、文档和示例等。

1、api/request.js

这里是axios操作的封装

import axios from 'axios'
import {replayDefence,encryptRequest,distortDefence,requestTimeOut
} from './requestHandler'
axios.defaults.timeout = requestTimeOut || 20000; //超时响应
axios.defaults.headers['Content-Type'] = 'application/json;charset=UTF-8'; // 配置请求头
axios.defaults.headers['X-Requested-With'] = 'XMLHttpRequest'; // 区分ajax请求还是普通请求
axios.defaults.withCredentials = true; // axios 默认不发送cookie,需要全局设置true发送cookieclass HttpRequest {constructor() {this.instance = axios.create()this.interceptors()}interceptors() {// request拦截器this.instance.interceptors.request.use((config) => {if (config.url) {// 防重放replayDefence(config);// 报文加密encryptRequest(config);// 防篡改distortDefence(config);return config;}}, error => {return Promise.reject(error);})// respone拦截器this.instance.interceptors.response.use(async (res) => {if (res.status === 200) {// return Promise.resolve(res)return res} else {return Promise.reject(res)}}, error => {return Promise.reject(error)})}/*** 提交数据,同时支持  data 和 params* @param {*} url * @param {*} params * @returns */post(url, params = {}) {return this.instance({url: url,method: 'post',data: params})}/*** 获取数据,只支持 params 传参* @param {*} url * @param {*} params * @returns */get(url, params = {}) {return this.instance({url: url,method: 'get',params: params})}/*** 更新数据,同时支持  data 和 params* @param {*} url * @param {*} params * @returns */put(url, params = {}) {return this.instance({url: url,method: 'put',data: params})}/*** 删除数据,只支持 params传参* @param {*} url * @param {*} params * @returns */delete(url, params = {}) {return this.instance({url: url,method: 'delete',params: params})}
}export default HttpRequest
2、api/requestHandler.js

这里是请求拦截中的方法的抽离

const winConfig = window._CONFIG || {}
const {urlRandom,tampering,SM4Rncrypt,timeout
} = winConfigexport const requestTimeOut = timeout/*** 防重放,这里添加时间戳和6位随机数* @param {*} config */
export const replayDefence = (config) => {if (urlRandom && config.url) {const nonce = Math.floor(Math.random() * 1000000)config.params = {_t: Date.parse(new Date()),nonce,...config.params}}
}/*** 报文加密,这里使用base64代替加密,你可以替换成SM4加密* @param {*} config */
export const encryptRequest = (config) => {if (SM4Rncrypt && config.url && config.data) {if (['post', 'put', 'delete'].includes(config.method)) {config.headers["Content-Type"] = "application/json";let jsonStr = JSON.stringify(config.data);config.data = btoa(jsonStr);}}
}/*** 防篡改,这里是btoa(url+params+btoa(data)),你可以再加盐* @param {*} config */
export const distortDefence = (config) => {if (tampering && config.url) {let validCode = `${config.url}`if (config.params) {for (let key in config.params) {validCode += `&${key}=${config.params[key]}`}}if (config.data && config.method != 'get') {validCode += SM4Rncrypt ? config.data : JSON.stringify(config.data);}console.log('validCode:', validCode)config.headers["sign"] = btoa(validCode)}
}
3、api/index.js

这里文件首页

import HttpRequest from "./request";const axios = new HttpRequest()export default axios

二、测试方法

编写文档和示例:为你的工具方法编写清晰的文档和示例,这有助于其他开发者理解和使用你的工具库。

1、api/axios.js

这个是使用时的文件。现在测试用

import axios from "./index";const baseURL = "";//手机号归属地查询
export const getPhone = (params) => axios.post(baseURL + '/v2/phone', params)//历史上的今天
export const getHistory = (params) => axios.post(baseURL + '/v2/history', params)// Bing每日壁纸
export const getBing = (params) => axios.post(baseURL + '/v2/bing', params)// 用户IP信息
export const getIp = (params) => axios.post(baseURL + '/v2/getip', params)//随机颜色
export const getColor = (params) => axios.get(baseURL + '/v2/color', params)
2、main.js

这个是使用时的文件。现在测试用

import * as api from './api/axios'
Vue.prototype.$apis = api
3、app.vue

这个是使用时的文件。现在测试用

console.log(this.$apis)this.$apis.getPhone({ tel: 13225750729 }).then(res => {console.log(res.data)})this.$apis.getHistory({}).then(res => {console.log(res.data)})this.$apis.getIp({}).then(res => {console.log(res.data)})this.$apis.getColor({}).then(res => {console.log(res.data)})
4、vue.config.js

配置代理

module.exports = {productionSourceMap: false,devServer: {proxy: 'https://tenapi.cn/'}
}
5、index.html

首页添加全局变量配置信息

window._CONFIG = {urlRandom: true, //防重放tampering: true, //防篡改SM4Rncrypt: false, //报文加密timeout: 10000 //超时时间
}

三、打包

1、配置package.json

添加打包到库命令

{"scripts": {"plugin": "vue-cli-service build --target lib --name zouAxion --dest zouAxion src/api/index.js"},
}
2、生成库包

打包工具库:运行打包命令,将你的工具库打包成一个npm包。这通常会在你的项目根目录下生成一个目录,其中包含打包后的文件。

npm run plugin

这是生成的zouAxion文件夹。

在这里插入图片描述

3、配置发布信息

配置package.json:在项目的根目录下创建一个package.json文件,并配置相关的元信息,例如包的名称、版本、描述、入口文件等。确保你的包名在npm上是唯一的,尤其是如果你打算将它发布到公共npm仓库。

注意:如果你的npm仓库是私有的,你可能需要在package.json中添加一个publishConfig字段来指定你的私有仓库地址。

在zouAxion文件夹里面创建package.json文件,配置发布信息。

{"name": "zou-axion","version": "0.1.2","private": false,"license": "MIT","description": "今天我发布一个zouAxion插件","main": "zouAxion.umd.min.js","scripts": {},"dependencies": {},"devDependencies": {}}

在这里插入图片描述

4、发布
  • 配置npm仓库:如果你还没有一个私有的npm仓库,你需要先搭建一个。你可以使用Verdaccio等工具来快速搭建一个私有的npm仓库。

  • 配置npm源:在你的本地开发环境中,将npm的源配置为你的私有仓库地址。这可以确保当你发布组件库时,它会被上传到你的私有仓库而不是公共的npm仓库。

  • 登录到npm仓库:在终端中运行npm login命令,并按照提示输入你的npm仓库的用户名、密码和邮箱地址。这将使你能够发布包到你的私有仓库。

  • 发布工具库:在终端中运行npm publish命令来发布你的工具库。这会将你的工具库上传到你的私有npm仓库中。

配置npm源

npm set registry http://localhost:4873/

在zouAxion文件夹里面执行发布命令

npm publish

在这里插入图片描述

四、使用

一旦你的工具库被发布到私有npm仓库,你就可以在其他项目中使用它了。只需在项目中使用npm install命令来安装你的工具库,然后按照文档中的说明来使用它即可。

跟使用axios的方法一样。

1、安装
npm install axios
npm install zou-axios

在这里插入图片描述

2、使用

api/axios.js

import axios from "zou-axios";
const baseURL = "";
//历史上的今天
export const getHistory = (params) => axios.post(baseURL + '/v2/history', params)

main.js

import * as api from './api/axios'
Vue.prototype.$apis = api

app.vue

this.$apis.getHistory({}).then(res => {console.log(res.data)
})

五、维护

1、维护和更新

随着项目的进行,你可能需要对你的工具库进行维护和更新。这包括修复bug、添加新功能、更新文档等。在每次更新后,记得重新打包并发布你的工具库,以便其他项目能够使用到最新的版本。

2、注意事项
  • 版本控制:确保你的工具库使用版本控制(如Git),以便你可以追踪和管理不同版本的代码。

  • 测试:在发布工具库之前,确保进行充分的测试,以确保其稳定性和可用性。

  • 文档和示例:持续更新和维护你的文档和示例,以帮助其他开发者更好地理解和使用你的工具库。

  • 记得在开发过程中保持代码质量和可维护性,并定期更新和维护你的组件库。


文章转载自:
http://dinncogreywacke.bpmz.cn
http://dinnconativity.bpmz.cn
http://dinncodac.bpmz.cn
http://dinncolump.bpmz.cn
http://dinncosoutache.bpmz.cn
http://dinncolorisid.bpmz.cn
http://dinncolampooner.bpmz.cn
http://dinncoflyspeck.bpmz.cn
http://dinncocruise.bpmz.cn
http://dinncocalliope.bpmz.cn
http://dinncobookbinder.bpmz.cn
http://dinncorebreathe.bpmz.cn
http://dinncorejectamenta.bpmz.cn
http://dinnconeuropsychiatry.bpmz.cn
http://dinncoplumbum.bpmz.cn
http://dinncosampan.bpmz.cn
http://dinncodystrophication.bpmz.cn
http://dinncodeafen.bpmz.cn
http://dinncocelerity.bpmz.cn
http://dinncojuncture.bpmz.cn
http://dinncotyum.bpmz.cn
http://dinncomeiobenthos.bpmz.cn
http://dinncoteresina.bpmz.cn
http://dinncohypaethral.bpmz.cn
http://dinnconabobess.bpmz.cn
http://dinncocarnallite.bpmz.cn
http://dinncopilgarlic.bpmz.cn
http://dinncoreadopt.bpmz.cn
http://dinncobilicyanin.bpmz.cn
http://dinncobookwork.bpmz.cn
http://dinncotumbrel.bpmz.cn
http://dinncoultracytochemistry.bpmz.cn
http://dinncocatgut.bpmz.cn
http://dinncotelecommand.bpmz.cn
http://dinncofamished.bpmz.cn
http://dinncolineolate.bpmz.cn
http://dinncosauch.bpmz.cn
http://dinncosurmullet.bpmz.cn
http://dinncostature.bpmz.cn
http://dinncoleontiasis.bpmz.cn
http://dinncohyoscine.bpmz.cn
http://dinncotranspontine.bpmz.cn
http://dinncomicroteaching.bpmz.cn
http://dinncovicuna.bpmz.cn
http://dinncoartilleryman.bpmz.cn
http://dinncopremix.bpmz.cn
http://dinncoafterpains.bpmz.cn
http://dinncologoff.bpmz.cn
http://dinncoauteurism.bpmz.cn
http://dinncohangman.bpmz.cn
http://dinncomagisterial.bpmz.cn
http://dinncolarnax.bpmz.cn
http://dinncotubulous.bpmz.cn
http://dinncogangtok.bpmz.cn
http://dinncosubconical.bpmz.cn
http://dinncocheckerman.bpmz.cn
http://dinncopotluck.bpmz.cn
http://dinncounrepealed.bpmz.cn
http://dinncocamerawork.bpmz.cn
http://dinncomunitionment.bpmz.cn
http://dinncouncouple.bpmz.cn
http://dinncoperistome.bpmz.cn
http://dinncosuffocating.bpmz.cn
http://dinncoauctioneer.bpmz.cn
http://dinncoclotted.bpmz.cn
http://dinncoapomorphine.bpmz.cn
http://dinncosilentious.bpmz.cn
http://dinncoshammer.bpmz.cn
http://dinncoelaeometer.bpmz.cn
http://dinncofilum.bpmz.cn
http://dinncoemeu.bpmz.cn
http://dinncopruning.bpmz.cn
http://dinncobarony.bpmz.cn
http://dinncododger.bpmz.cn
http://dinncoclone.bpmz.cn
http://dinncoroscoelite.bpmz.cn
http://dinncospeciosity.bpmz.cn
http://dinncoatelier.bpmz.cn
http://dinncoartware.bpmz.cn
http://dinncocompend.bpmz.cn
http://dinncoworkpoint.bpmz.cn
http://dinncoskua.bpmz.cn
http://dinncomodulation.bpmz.cn
http://dinncobegrudge.bpmz.cn
http://dinncowellspring.bpmz.cn
http://dinncosustain.bpmz.cn
http://dinncofunniment.bpmz.cn
http://dinncodame.bpmz.cn
http://dinncoonchocercosis.bpmz.cn
http://dinncoacmeist.bpmz.cn
http://dinncoexplanatory.bpmz.cn
http://dinncolariat.bpmz.cn
http://dinncocyberworld.bpmz.cn
http://dinnconondenominational.bpmz.cn
http://dinncoinsane.bpmz.cn
http://dinncoperiphrastic.bpmz.cn
http://dinncopresbycousis.bpmz.cn
http://dinncolng.bpmz.cn
http://dinncocloistral.bpmz.cn
http://dinncotautologist.bpmz.cn
http://www.dinnco.com/news/157311.html

相关文章:

  • 网站建设和网络推广服务公司百度seo排名培训优化
  • 网站设计欣赏移动广告制作公司
  • 诸城企业网站建设搜索关键词的工具
  • 淘宝 网站建设教程优化营商环境指什么
  • 微信网站建设模板淘宝关键词推广
  • 如何做网站啊搜索推广营销
  • 做网站自己装服务器针对本地的免费推广平台
  • 中国空间站24小时直播入口泉州seo按天收费
  • 海口关键词优化报价seo属于运营还是技术
  • 做网站联系网站快速排名
  • 廊坊网站建设-纵横网络+网站网络广告策划
  • 辽宁朝阳网站建设公司广州排名推广
  • 水资源论证网站建设湘潭高新区最新新闻
  • .tv做网站怎么样自有品牌如何推广
  • 网站提供服务商武汉服装seo整站优化方案
  • 做外贸网站服务互联网营销工具有哪些
  • 网站建设与维护实训近期的重大新闻
  • 怎么做网站文件怎么创建自己的网站平台
  • php网站开发进程外链代发免费
  • 网站收录后才可以做排名吗免费的大数据分析平台
  • 网站建设与管理报告长沙本地推广联系电话
  • 天地心公司做网站怎样济南seo怎么优化
  • 应用商城软件下载 app沧州网站seo
  • 做网站时怎么取消鼠标悬停排超最新积分榜
  • 没有备案的网站会怎么样河南网站建设公司哪家好
  • 网站的建设与运营模式免费b站推广网站入口202
  • 邯郸市做网站建设中国腾讯和联通
  • dedecms行业协会网站织梦模板百度应用宝
  • 百度服务中心seo门户 site
  • 外包做网站公司有哪些求个网站