课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

服务端和客户端的代码重用

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

当你在 CoffeeScript 上创建了一个函数,并希望将它用在有网页浏览器的客户端和有 Node.js 的服务端时。

解决方案

以下列方法输出函数:

  1. # simpleMath.coffee
  2. # these methods are private
  3. add = (a, b) ->
  4. a + b
  5. subtract = (a, b) ->
  6. a - b
  7. square = (x) ->
  8. x * x
  9. # create a namespace to export our public methods
  10. SimpleMath = exports? and exports or @SimpleMath = {}
  11. # items attached to our namespace are available in Node.js as well as client browsers
  12. class SimpleMath.Calculator
  13. add: add
  14. subtract: subtract
  15. square: square

讨论

在上面的例子中,我们创建了一个新的名为 “SimpleMath” 的命名空间。如果 “export” 是有效的,我们的类就会作为一个 Node.js 模块输出。如果 “export” 是无效的,那么 “SimpleMath” 就会被加入全局命名空间,这样就可以被我们的网页使用了。

在 Node.js 中,我们可以使用 “require” 命令包含我们的模块。

  1. $ node
  2. > var SimpleMath = require('./simpleMath');
  3. undefined
  4. > var Calc = new SimpleMath.Calculator();
  5. undefined
  6. > console.log("5 + 6 = ", Calc.add(5, 6));
  7. 5 + 6 = 11
  8. undefined
  9. >

在网页中,我们可以通过将模块作为一个脚本嵌入其中。

  1. <!DOCTYPE HTML>
  2. <html lang="en-US">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>SimpleMath Module Example</title>
  6. <script src="//img.w3cschool.cn/attachments/image/wk/coffeescript/jquery.min.js"></script>
  7. <script src="simpleMath.js"></script>
  8. <script>
  9. jQuery(document).ready(function (){
  10. var Calculator = new SimpleMath.Calculator();
  11. var result = $('<li>').html("5 + 6 = " + Calculator.add(5, 6));
  12. $('#SampleResults').append(result);
  13. });
  14. </script>
  15. </head>
  16. <body>
  17. <h1>A SimpleMath Example</h1>
  18. <ul id="SampleResults"></ul>
  19. </body>
  20. </html>

输出结果:

A SimpleMath Example

· 5 + 6 = 11

转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号