Cnblogs博客皮膚開發調試最佳方案

来源:https://www.cnblogs.com/alson/archive/2023/02/10/17108843.html
-Advertisement-
Play Games

回顧第一篇文章中談到的組件庫的幾個方面,只剩下最後的、也是最重要的組件庫的打包構建、本地發佈、遠程發佈了。 1 組件庫構建 組件庫的入口是 packages/yyg-demo-ui,構建組件庫有兩個步驟: 添加 TypeScript 的配置文件: tsconfig.json 添加 vite.conf ...


Cnblogs博客園支持自定義js來美化站點(需要申請JS許可權),可以將主題托管到自己的雲資源或CDN加速節點節點上。

例如我的網站為 www.example.com(IP或其它host),我將編譯後的文件夾 dist 放到了網站的根目錄。

這樣我可以通過載入 https://www.example.com/dist/simpleMemory.js 來載入主題:

<script type="text/javascript">
    window.cnblogsConfig = {
      info: {
        name: 'userName', // 用戶名
        startDate: '2021-01-01', // 入園時間,年-月-日。入園時間查看方法:滑鼠停留園齡時間上,會顯示入園時間
        avatar: 'http://xxxx.png', // 用戶頭像
      },
    }
</script>
<script src="https://www.example.com/dist/simpleMemory.js" defer></script>

當主題需要自定義一些功能,發現不方便調試js腳本,要反覆將生產包部署到伺服器,來回操作繁瑣複雜,現可以通過雲開發方式來做調試。

開發環境 - 使用Codespaces調試開發

fork倉庫後,如果沒有雲資源又想要調試代碼,這時候可以嘗試github推出的codespaces雲IDE。

  • 在github上創建一個codespaces

創建codespaces

  1. control + shift + ~打開終端,執行命令語句 npm run server

打開終端,執行命令語句

  1. 切換到埠面板, 右鍵鏈接地址,更改埠可見性為public

右鍵鏈接地址,更改埠可見性為

  1. 打開鏈接地址,就能看到dist為目錄的站點

dist站點

  1. 最後在csblogs博客設置中,臨時將script腳本地址替換

打開終端,執行命令語句

在codespaces編譯後,在刷新博客園網站就能看到更改後的內容

github codespaces 每個月免費時長為120 core/h,2核數CPU可以使用60h。

打包後dist包部署到伺服器。

生產環境 - 雲伺服器Docker容器化

註意Cnblogs是https站點,所以引入第三方資源的站點也必須是https,詳見https混合內容

1. 申請SSL證書(已有證書跳過此步驟)
  • ZeroSSL申請證書為例, 面板中點擊New Certificate,輸入IP地址-選擇90天免費證書
    創建ZeroSSL

  • 驗證功能變數名稱所有權,下載驗證文件,替換倉庫路徑./well-known/pki-validation下的.txt文件
    創建ZeroSSL

  • 伺服器中拉取倉庫代碼, 執行docker-compose up -d - ZeroSSL點擊校驗

2. 安裝證書
  • ZeroSSl下載的證書包,需要將模塊包ca-boundle.crt和併到certificate.crt中(手動扣過去就行),並替換倉庫ssl下的證書文件
  • 伺服器拉取最新代碼,執行docker-compose up -d --force-recreate --build --remove-orphans

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 數據治理是推動大型集團企業轉型升級、提升競爭優勢、實現高質量發展的重要引擎。通過全鏈數據結構化,實現業務對象、業務規則、業務流程數字化,推進全鏈業務深度數字化,夯實數據運營底座。 某大型實業集團創立於1980年,主要業務涵蓋供應鏈運營、城市建設與運營、旅游會展、 醫療健康、新興產業投資等多個領域。位 ...
  • 2023-02-10 一、redis提供了2個不同形式的持久化方式 1、RDB(Redis DataBase) 2、AOF(Append Of File) 二、RDB的定義 RDB是在指定的時間間隔內將記憶體中的數據集快照寫入磁碟,即Snapshot快照,它恢復時是將快照文件直接讀到記憶體里。 三、備份 ...
  • 大家都知道 MySQL 的數據都是保存在磁碟的,那具體是保存在哪個文件呢?MySQL 存儲的行為是由存儲引擎實現的,MySQL 支持多種存儲引擎,不同的存儲引擎保存的文件自然也不同。InnoDB 是我們常用的存儲引擎,也是 MySQL 預設的存儲引擎。本文主要以 InnoDB 存儲引擎展開討論。 ...
  • NineData 是多雲數據管理平臺(https://www.ninedata.cloud/),致力於讓每個人用好數據和雲。作為資料庫領域的技術創新團隊,面對這麼火ChatGPT,我們 NineData 的工程師也針對ChatGPT,做了一些關於資料庫領域的相關測試,測試結果,真的是智商狂飆。 ...
  • vuex是什麼? vuex是管理應用程式狀態,實現組件間通信的。 為什麼使用vuex? 在開發大型應用的項目時,會出現多個視圖組件依賴一個同一個狀態,來自不同視圖的行為需要變更同一個狀態。 在遇到以上問題,就要用到vuex,他能把組件的共用狀態抽取出來,當做一個全局單例模式進行管理,不管在何處改變狀 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 很多前端都喜歡用 console.log 調試,先不談調試效率怎麼樣,首先 console.log 有個致命的問題:會導致記憶體泄漏。 為什麼這麼說呢? 用 Performance 和 Memory 工具分析下就知道了。 我們準備這樣一段代 ...
  • 1.【配置】應用版本號名稱有一個規則的字元串:1.0.0,規則是:大版本號,中版本號,小版本號。 2.【配置】應用版本號中的小版本號不能超過9,超過9的需要向上一個版本號進一(逢十進一)。 3.【配置】應用版本號是一個整數類型,最長10位,超過10位就會被自動轉化成字元串。 4.【配置】應用版本號和 ...
  • 函數: 一個被設計為執行特定任務的代碼塊 語法 通過function 關鍵詞定義,後面跟著其函數名稱,然後是一對圓括弧,圓括弧中可以定義一些函數的參數。沒有名稱的函數呢? 函數名稱可以包含字母、數字、下劃線、中劃線和美元符號(命名規則與變數命名一致)。 // 聲明一個函數 function fnNa ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...