以檔名啟動程式
$ pm2 start 檔名 --name app_name
以指令啟動程式
$ pm2 start '指令' --name app_name
指令因為有空白,要用引號包起來,或者也可以把指令做成sh檔,就可以以檔名啟動的方式來做。 閱讀全文 PM2 常用指令筆記
以檔名啟動程式
$ pm2 start 檔名 --name app_name
以指令啟動程式
$ pm2 start '指令' --name app_name
善用 display: grid 來處理排版真的非常方便,不但可以簡化html巢狀結構,在處理RWD的時候,也增加了更多排版的彈性跟可能性。例如可以用 grid-template-areas 來隨意調整排版的位置順序等等。
說到 colspan 的話,上述提到的 grid-template-areas 也可以輕鬆達到這個需求,例如以下範例:
閱讀全文 在CSS GRID Layout實現colspan, rowspan關於權重的計算,在W3C的網頁上的介紹是:
常常在一些情況之下,css selector有可能會需要寫很長,尤其是剛開始在寫sass, scss時,巢狀寫的很開心,結果compile出來的東西有可能會像下面這樣:
.container .class1 article, | |
.container .class2 article, | |
.container .class3 article, | |
.container .class4 article { | |
color: #f00; | |
} |
而 :is() 跟 :where() 就是用來解決這個問題。在is:() or :where() 中可以帶入逗點分格的selector,讓原本多行且重複的結構簡化為一行:
閱讀全文 CSS :is, :where Selector首先是關於this的使用,fetch 中的 this 指的就是component本身,asyncData 的this則是undefined。且fetch可以被component本身用
this.$fetch()
再次呼叫,而asyncData不行。
再來是顯示的效果。server-side render時感覺不出來,不過在client side render時,就有明顯差異。兩者分別運作的流程如下:
點擊連結 -> asyncData() -> 組件建立完成 -> render畫面(換頁)
點擊連結 -> 組件建立完成 -> render畫面(換頁) -> fetch()
使用asyncData的話,會先取資料,取完資料才換頁。使用fetch的話,取資料前就會先換頁,等到資料取完後,才會填入資料。
閱讀全文 Nuxt asyncData與fetch的不同前陣子需要利用server middleware做fb oauth功能,於是我就在middleware資料夾新增了fbauth.js,內容:
export default async function (req, res, next) { | |
var querystring = require('querystring') | |
var axios = require('axios') | |
var query = querystring.parse(req._parsedOriginalUrl.query) | |
var appId = query.appId | |
var redirectUri = query.redirectUri.replace('#_=_', '') | |
var code = query.code | |
if (!appId || !redirectUri || !code) { | |
// response fail | |
res.writeHead(404, { 'Content-Type': 'application/json' }) | |
res.end(JSON.stringify({ msg: 'Login Failed' })) | |
return false | |
} | |
try { | |
// get access token | |
var clientSecret = process.env.FB_APP_SECRET | |
var url = `https://graph.facebook.com/v6.0/oauth/access_token?client_id=${appId}&redirect_uri=${redirectUri}&client_secret=${clientSecret}&code=${code}` | |
var result = await axios.get(url) | |
var token = result.data.access_token | |
// get userid | |
var useridUrl = `https://graph.facebook.com/me?&access_token=${token}` | |
var uinfo = await axios.get(useridUrl) | |
var uid = uinfo.data.id | |
// response success | |
res.writeHead(200, { 'Content-Type': 'application/json' }) | |
res.end(JSON.stringify({ token: token, uid: uid })) | |
} catch (e) { | |
// response fail | |
res.writeHead(404, { 'Content-Type': 'application/json' }) | |
res.end(JSON.stringify({ msg: 'Auth Failed' })) | |
} | |
} |
結果build完之後,發現clientSecret竟然也一起打包進client端的js裡!!
於是我查了關於如何不將code打包進client side的資料後,就在外面包了一層 if (process.env.VUE_ENV === ‘server’) 如下:
閱讀全文 Nuxt Server-Middleware不好意思惡搞了小英,但唯有小英的炸裂式大笑,才可以詮釋我內心對於破音的澎湃(不知為何從小就對破音愛到無法自拔)。司儀叔叔我愛你!你太酷了!
由40位網友合力完成的大合唱,音樂由Kej演奏
請大家支持婚姻平權,祝福台灣人權大躍進
這是個讓你一秒換瀏覽器分頁ICON跟標題的教學。可以讓你在不須關閉分頁的情況之下,分頁列上的內容不至於被發現你在看不該看的東西。步驟如下:
把這個連結-> 收件夾 – nihao78@gmail.com拉到工具列上
閱讀全文 上班時間的瀏覽器分頁名稱隱身術這是一個造型非常簡單的鬧鐘,方方正正的造型,僅黑白的顏色,只有上方有一凹陷。
天亮鬧鐘一響,非得在凹槽中擲下鬧鐘所附的骰子,並且符合鬧鐘右下角的隨機組合,鬧種才肯罷休。
時鐘的各項設定功能,也只需要用骰子,觸碰凹槽的感應裝置,即可完成時間與鬧鐘設定。
因為公司同事生日,想別於以往溫和的整人方式,於是別出心裁的製作了可以放碎紙花在裡面的假天花板
材料:
1.全開壁報紙一張
2.厚紙板,只需要可以繞成一圈寬三公分作框的大小即可
3.粗細不同麥克筆數支,一隻也是可以啦只是手很酸
4.魚線
5.碎紙花,或你想放些別的也可以