ClojureScript魔法堂:搭建开发环境

简介:

一、前言                              

  当看到Lisp等函数式编程语言的语法是 (say (concat "hello" "world")) 这 样的时候,我就有种深入学习的冲动,因为它的语法和自己一直使用的Java、C#都不同,酷比了!(我承认我是语法控^_^)又由于我主要玩的是 JavaScript,恰好ClojureScript就是纯函数式的JS超集,于是决定以ClojureScript作为函数式编程的起点。(虽然 JavaScript具有函数式语言的特点:函数为一等公民,闭包等)

  本文作为开篇,首先是在Windows7下搭建ClojureScript的开发环境。

 

二、被主页忽悠了                              

  ClojureScript@githubQuickStart中 提供了Windows下安装的两种途径,1. 安装Cygwin然后适当修改项目的bootstrap、文件,再依照xinux的安装方式即可;2. 下载地址依赖包和并根据步骤配置。然后各种折腾后发现repl是可以运行的,但repljs和cljsc却无法运行。。。。。。

 

三、正解——Leiningen + cljsbuild打环境               

  Leiningen是Clojure和ClojureScript的构建工具,相当于Java的Maven+Ant。

  首先我们到Leiningen@github上下载2.1.2以上的bat文件(我下载了2.5.1版本)然后在当前目录下执行 lein self-install ,该批处理程序就会自动将jar包下载到当前用户家目录下的 .lein/self-install/ 下了

  接着我们执行 lein new <project-name> 新建一个Clojure项目,然后修改project.clj来配置关于项目依赖项和插件的元数据,从而使用lein-cljsbuild插件。

  project.clj文件内容如下:

(defproject myapp "0.1.0-SNAPSHOT"
  :description "FIXME: write description"
  :url "http://example.com/FIXME"
  :license {:name "Eclipse Public License"
            :url "http://www.eclipse.org/legal/epl-v10.html"}
  :dependencies [[org.clojure/clojure "1.6.0"]
                 [org.clojure/clojurescript "0.0-2411"
                  :exclusions [org.apache.ant/ant]]
                 [compojure "1.1.6"]]
  :plugins [[lein-cljsbuild "1.0.4"]]
  :cljsbuild {
    :builds [{:id "main"
              :source-paths ["src-cljs"]
              :compiler {:output-to "js/main.js"
                           :output-dir "out"
                         :optimizations :none
                         :source-map true}}]})

  接着执行 lein cljsbuild auto 启动实时编译功能,现在我们可以在src-cljs目录下编写ClojureScript并实时查看到编译后的JS代码。

 

四、总结                            

  暂时仅留爪印,日后继续补充。

目录
相关文章
|
6月前
|
存储 JSON API
精选6个C++项目,推荐新人练手首选!(上)
精选6个C++项目,推荐新人练手首选!
精选6个C++项目,推荐新人练手首选!(上)
|
4月前
|
存储 运维 安全
年终总结:官网搭建知多少
官网搭建的核心工作可以分为以下5个部分,找到每一步的最佳解决方案,专属企业官网就近在眼前啦!
|
6月前
|
缓存 算法 Linux
精选6个C++项目,推荐新人练手首选!(下)
精选6个C++项目,推荐新人练手首选!
|
9月前
|
存储 数据可视化 搜索推荐
思维导图软件哪个好用?盘点20款不容错过的思维导图软件!
整理9种类型,共20款思维导图软件,看哪款更戳你
|
9月前
|
存储 安全
[免费]微课设计零基础入门 | 3.制作微课必备字体的选择与安装
你说,现在当老师可真不容易啊!就拿微课来说吧,硬是把一个个文质彬彬的老师弄得像IT工程师一样,又是破解又是汉化,又是录屏又是剪辑的……居然还有人在说老师每天只工作一天个小时……哎,说多了,都是辛酸泪!
114 0
|
9月前
|
Web App开发 移动开发 缓存
📚一站式解决:H5开发全攻略,看这篇让你省时又省力-1
响应式布局 在 H5 中,我们通常会使用 REM 和 VW 这两种单位来实现页面的响应式布局。这两种单位可以让页面元素的大小随着根元素(对于 REM)或视口宽度(对于 VW)的大小变化而变化,从而适应不同尺寸的屏幕。
100 0
|
9月前
|
Web App开发 移动开发 前端开发
📚一站式解决:H5开发全攻略,看这篇让你省时又省力-3
⭐️⭐️border-radius 画出的圆在移动端有毛边 解决方案 给元素添加 overflow: hidden 属性。
127 0
|
9月前
|
Web App开发 传感器 移动开发
📚一站式解决:H5开发全攻略,看这篇让你省时又省力-2
⭐️⭐️对齐下拉选项 通过设置direction: rtl,可以改变下拉框选项的对齐方式,使其从右向左排列。
76 0
|
11月前
|
人工智能 小程序 数据安全/隐私保护
分享几个免费设计生成工具 (第二期)
今天来给大家分享几个国外免费的设计生成工具
|
11月前
|
人工智能 程序员 Linux
【猿如意】CSDN推出的程序猿开发百宝箱
【猿如意】CSDN推出的程序猿开发百宝箱
155 0

热门文章

最新文章