GitHub 地址:https://github.com/dom-bro/task-manager
想要项目快速迭代,轮子必不可少。normalize.css,element-plus,axios,moment,vue-router,less,前端必知必会的轮子你都知道吗?
npm i normalize.css
只需在 src/main.js 中加一行即可
import 'normalize.css'
这个库主要做的事是统一浏览器默认样式,而非清除浏览器默认样式。所以像 h1,h2,strong 这种自带样式的标签仍然保留着样式,body 的 margin 统一成了 0
npm i element-plus
由于是全栈开发,产品 -> UI -> 前端 -> 后端 -> 数据库,写代码我还行,ps 和 skecth 实在是力不从心啊,搞一个 UI 框架是必要的。
关键代码
import 'element-plus/dist/index.css'
import ElementPlus from 'element-plus'
app.use(ElementPlus)
由于是要在整个项目中用,并且 element-plus 提供的大多数组件都要被用到。这里就直接简单粗暴的完整引入。
当然在具体的项目中也可以根据实际情况按需引入
npm i axios
import axios from 'axios'
window.axios = axios
我身为一个前段开发师,定义几个全局变量很合理吧
npm i moment
import moment from 'moment'
window.moment = moment
正如我刚才所说,moment 每个页面到处都在用,定义成全局变量也很合逻辑
npm i vue-router
vue 的官方路由,不需要解释。
import { createRouter, createWebHistory } from 'vue-router'
const router = createRouter({
history: createWebHistory(),
routes: [],
})
app.use(router)
在添加了前端路由之后才真正算是正式开工了
接下来就可以一个页面一个页面地稳步前进啦
npm i less
在 vue 的 sfc 里就可以用 less 啦
<style lang="less"></style>
把 vite 脚手架生成的一些 hello world 示例代码清理一下
新建一个首页路由
{
path: '/',
component: () => import('./pages/Home.vue')
},
上图右半拉是不可不知的 vue 开发调试神器 vue-devtools。官方出品,必属精品。
现在项目的主要依赖如下
# 前端
vite 3
vue 3
vue-router 4
element-plus 2
# 服务端
koa 2
koa-router 12
# 环境
node v16.15.0
npm v8.5.5
正文结束。点击查看代码变更
element-plus 是 element-ui 专门针对 vue3 出的版本。element-ui 和 ant-design-vue 都是极其优秀的框架,这俩框架我都有两年左右的实战项目经验。两者内含的常用组件不能说是雷同,简直是一摸一样。作为 ui 框架,主要的差异还是 ui 层面的。
选择 element-ui 也是因为先入为主,要知道在 2018 年启动这个项目时我甚至都没听说过 ant-design-vue
其实我从事前端的前几年主要是在用 sass 的,官网号称其是世界上最成熟、稳定和强大的 css 扩展语言,实至名归,支持的特性确实多。但安装起来咋就那么曲折呢,那个 node-sass 真是安一次,恼火一次。
后来接触了 less,虽然没 sass 功能强大,但常用的变量,嵌套,mixin,函数等特性足够用了啊,而且如此轻便,果断弃 sass,全面转向 less。
两者的特性差异我倒是没研究过。不过我知道 fetch api 在浏览器环境有,在 node 环境却没有,为了获得一致的开发体验,强迫症的我还是选择 axios
一句话,我选 history 模式纯粹是为了 url 美观。
hash 模式利用 window 的 hashchange 事件监听 url hash 部分的变化,从而匹配到对应的路由视图。url 的 hash 部分是不会发送到服务器的,所以这种模式完全由前端维护,服务器无需任何处理。缺点就是对 SEO 不友好,url 也比较丑陋。
history 模式充分利用了 history.pushState API 在实现 URL 跳转的同时不重新加载页面。这种模式下 url 就是正常的 url,但是这种正常的 url 在加载页面时走服务器请求,所以如果服务器不配置的话会出现 404,要解决这个问题需要在服务器添加一个简单的回退路由,在 URL 不匹配任何静态资源的情况下,返回 index.html。
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="
假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit
//1.验证返回状态码是否是200pm.test("Statuscodeis200",function(){pm.response.to.have.status(200);});//2.验证返回body内是否含有某个值pm.test("Bodymatchesstring",function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");});//3.验证某个返回值是否是100pm.test("Yourtestname",function(){varjsonData=pm.response.json
1.在Python3中,下列关于数学运算结果正确的是:(B)a=10b=3print(a//b)print(a%b)print(a/b)A.3,3,3.3333...B.3,1,3.3333...C.3.3333...,3.3333...,3D.3.3333...,1,3.3333...解析: 在Python中,//表示地板除(向下取整),%表示取余,/表示除(Python2向下取整返回3)2.如下程序Python2会打印多少个数:(D)k=1000whilek>1: print(k)k=k/2A.1000 B.10C.11D.9解析: 按照题意每次循环K/2,直到K值小于等
我正在尝试创建一个带有项目符号字符的Ruby1.9.3字符串。str="•"+"helloworld"但是,当我输入它时,我收到有关非ASCII字符的语法错误。我该怎么做? 最佳答案 你可以把Unicode字符放在那里。str="\u2022"+"helloworld" 关于ruby-如何在Ruby字符串中插入项目符号字符?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1195
我的Rails站点使用了一个确实不是很好的gem。每次我需要做一些新的事情时,我最终不得不花费与向实际Rails项目添加代码一样多的时间来为gem添加功能。但我不介意,我将我的Gemfile设置为指向我的gem的GitHub分支(我尝试提交PR,但维护者似乎已经下台)。问题是我真的没有找到一种合理的方法来测试我添加到gem的新东西。在railsc中测试它会特别好,但我能想到的唯一方法是a)更改~/.rvm/gems/.../foo。rb,这看起来不对或者b)升级版本,推送到Github,然后运行bundleup,这除了耗时之外显然是一场灾难,因为我不确定我所做的promise是否正
我一直在尝试使用nanoc用于生成静态网站。我需要组织一个复杂的排列页面,我想让我的内容保持干燥。包含或合并的概念在nanoc系统中如何运作?我已阅读文档,但似乎找不到我想要的内容。例如:我如何获取两个部分内容项并将它们合并到一个新的内容项中。在staticmatic您可以在您的页面中执行以下操作。=partial('partials/shared/navigation')类似的约定在nanoc中如何运作? 最佳答案 这里是nanoc的作者。在nanoc中,部分是布局。因此,您可以拥有layouts/partials/shared/
我安装了ruby、yeoman,当我运行我的项目时,出现了这个错误:Warning:Running"compass:dist"(compass)taskWarning:YouneedtohaveRubyandCompassinstalledthistasktowork.Moreinfo:https://github.com/gruUse--forcetocontinue.Use--forcetocontinue.我有进入可变session目标的路径,但它不起作用。谁能帮帮我? 最佳答案 我必须运行这个:geminstallcom