Chrome插件开发-哔哩哔哩图床

之前寻找高速图床时,发现了哔哩哔哩,于是秉着尝试做一个浏览器插件的想法去做一个图床插件。通过填写用户的cookie,将图片上传到哔哩哔哩的图床上。

项目

项目地址
下载

截屏


坑一、不生效

通过查阅Chrome插件开发的文档,使用chrome.cookies.set(object details, function callback)设置Cookie

但是当配置全部填写时,反而设置不会生效。

// 这样代码能运行,但是不会生效
chrome.cookies.set({
  domain: 'www.baidu.com',
  expirationDate: 1505720700,
  httpOnly: false,
  name: "SESSDATA",
  path: "/",
  secure: false,
  url: 'https://www.baidu.com',
  value: this.token,
}, (cookie)=> {
   console.log(cookie);
})

然后尝试了很多办法,都没成功。于是我去Github搜了一下,便搜到了一个CookieSetterChromeExtension,然后查看他的代码,发现他是这样用的:

chrome.cookies.set({ url: url, name: name, value: value}, (data) => console.log(data));

我复制到本地试了一下,马上就成功了,我醉了。

坑二、No host permissions for cookies at url

报错

Unchecked runtime.lastError: No host permissions for cookies at url: "https://www.baidu.com/".

解决办法:需要先删除该应用,再安装

坑三、浏览器自定义元素输入框不能与Vue双向绑定

直接改变v-bind绑定的值并不会生效,需要取Dom节点修改

const img = document.querySelector('#img')
const markdown = document.querySelector('#markdown')
img.value = this.links[0].value
markdown.value = this.links[1].value

Chrome插件配置文件manifest.json

就不多解释了,详细解释可以看 manifest.json文件详解

{
  "manifest_version": 2,
  "name": "哔哩哔哩图床",
  "short_name": "哔哩哔哩图床",
  "description": "通过哔哩哔哩存储建立图床",
  "version": "0.0.1",
  "icons": {
    "16": "icons/favicon@16.png",
    "48": "icons/favicon@48.png",
    "64": "icons/favicon@64.png",
    "128": "icons/favicon.png"
  },
  "permissions": [
    "webRequest",
    "cookies",
    "tabs",
    "storage",
    "http://*/*",
    "https://*/*",
    "<all_urls>"
  ],
  "background": {
    "scripts": ["js/background.js"],
    "persistent":true
  },
  "browser_action": {
    "default_title": "哔哩哔哩图床",
    "default_icon": "icons/favicon.png"
  },
  "homepage_url": "https://github.com/xlzy520/bilibili-img-uploader"
}

复制链接

copyToClipboard(input) {
        const el = document.createElement('textarea')
        el.style.fontsize = '12pt'
        el.style.border = '0'
        el.style.padding = '0'
        el.style.margin = '0'
        el.style.position = 'absolute'
        el.style.left = '-9999px'
        el.setAttribute('readonly', '')
        el.value = input

        document.body.appendChild(el)
        el.select()

        let success = false
        try {
          success = document.execCommand('copy', true)
        } catch (err) {}

        document.body.removeChild(el)
        return success
      },

indexDB数据库操作

查看文档 idb-js

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,下面是微信-哔哩哔哩小程序一级页面设计的实验过程: 1. 确定页面主题和风格 首先需要确定页面的主题和风格,例如是娱乐、科技、教育等。确定好主题和风格后,需要考虑页面的色彩搭配、字体、布局等方面,以保证整个页面的统一性和美观度。 2. 设计页面布局 根据页面的主题和功能需求,设计页面的布局,包括页面的导航栏、内容区、底部标签等。需要注意的是,页面的布局应该简洁明了,不要过于复杂,以方便用户浏览和操作。 3. 设计页面元素 根据页面的布局,开始设计页面的元素,如图片、文字、按钮等。需要注意的是,页面的元素应该符合页面的主题和风格,并且要有足够的吸引力,以吸引用户的注意力。 4. 进行页面原型设计 在确定好页面布局和元素后,可以进行页面原型设计,将设计好的元素按照布局进行排版,形成页面的原型。需要注意的是,原型的设计应该符合用户的使用习惯和心理需求,以提高用户的体验度。 5. 进行页面UI设计 在完成页面原型设计后,可以进行页面UI设计,将原型的元素进行美化和优化,以提高页面的美观度和用户的体验度。需要注意的是,UI设计应该符合页面的主题和风格,并且要有足够的吸引力,以吸引用户的注意力。 6. 进行页面测试和优化 在完成页面UI设计后,可以进行页面测试和优化,检查页面的各个方面是否符合设计要求,并进行必要的优化和改进,以提高页面的效果和用户的体验度。 以上是微信-哔哩哔哩小程序一级页面设计的实验过程,希望能对你有所帮助。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值