1
0
mirror of https://github.com/astaxie/beego.git synced 2024-11-23 03:10:56 +00:00

Merge branch 'master' of github.com:astaxie/beego

This commit is contained in:
slene 2013-08-01 15:52:33 +08:00
commit 452478e779
3 changed files with 77 additions and 27 deletions

View File

@ -115,7 +115,7 @@
2013/04/13 19:36:17 [W] [stat views: no such file or directory] 2013/04/13 19:36:17 [W] [stat views: no such file or directory]
- 模板会自动重新加载不缓存。 - 模板每次使用都会重新加载进行缓存。
- 如果服务端出错,那么就会在浏览器端显示如下类似的截图: - 如果服务端出错,那么就会在浏览器端显示如下类似的截图:
![](images/dev.png) ![](images/dev.png)
@ -643,11 +643,11 @@ beego更加人性化的还有一个设计就是支持用户自定义字符串错
## response处理 ## response处理
response可能会有集中情况: response可能会有几种情况:
1. 模板输出 1. 模板输出
模板输出上面模板介绍里面已经介绍beego会在执行完相应的Controller里面的对应的Method之后输出到模板。 上面模板介绍里面已经介绍beego会在执行完相应的Controller里面的对应的Method之后输出到模板。
2. 跳转 2. 跳转
@ -686,7 +686,7 @@ beego中使用session相当方便只要在main入口函数中设置如下
this.TplNames = "index.tpl" this.TplNames = "index.tpl"
} }
上面的例子中我们知道session有几个方便的方法 session有几个方便的方法
- SetSession(name string, value interface{}) - SetSession(name string, value interface{})
- GetSession(name string) interface{} - GetSession(name string) interface{}

View File

@ -51,19 +51,13 @@ func (self *templatefile) visit(paths string, f os.FileInfo, err error) error {
if f == nil { if f == nil {
return err return err
} }
if f.IsDir() { if f.IsDir() || (f.Mode()&os.ModeSymlink) > 0 {
return nil return nil
} else if (f.Mode() & os.ModeSymlink) > 0 { }
if !HasTemplateEXt(paths) {
return nil return nil
} else {
hasExt := false
for _, v := range BeeTemplateExt {
if strings.HasSuffix(paths, v) {
hasExt = true
break
} }
}
if hasExt {
replace := strings.NewReplacer("\\", "/") replace := strings.NewReplacer("\\", "/")
a := []byte(paths) a := []byte(paths)
a = a[len([]byte(self.root)):] a = a[len([]byte(self.root)):]
@ -76,11 +70,18 @@ func (self *templatefile) visit(paths string, f os.FileInfo, err error) error {
self.files[subdir] = m self.files[subdir] = m
} }
}
}
return nil return nil
} }
func HasTemplateEXt(paths string) bool {
for _, v := range BeeTemplateExt {
if strings.HasSuffix(paths, "."+v) {
return true
}
}
return false
}
func AddTemplateExt(ext string) { func AddTemplateExt(ext string) {
for _, v := range BeeTemplateExt { for _, v := range BeeTemplateExt {
if v == ext { if v == ext {

49
template_test.go Normal file
View File

@ -0,0 +1,49 @@
package beego
import (
"os"
"path/filepath"
"testing"
)
func TestBuildTemplate(t *testing.T) {
dir := "_beeTmp"
files := []string{
"1.tpl",
"2.html",
"3.htmltpl",
"4.mystyle",
}
if err := os.MkdirAll(dir, 0777); err != nil {
t.Fatal(err)
}
for _, name := range files {
if _, err := os.Create(filepath.Join(dir, name)); err != nil {
t.Fatal(err)
}
}
if err := BuildTemplate(dir); err != nil {
t.Fatal(err)
}
if len(BeeTemplates) != 1 {
t.Fatalf("should be 1 but got %v", len(BeeTemplates))
}
for _, v := range BeeTemplates {
if len(v.Templates()) != 3 {
t.Errorf("should be 3 but got %v", len(v.Templates()))
}
}
AddTemplateExt("mystyle")
if err := BuildTemplate(dir); err != nil {
t.Fatal(err)
}
if len(BeeTemplates) != 1 {
t.Fatalf("should be 1 but got %v", len(BeeTemplates))
}
for _, v := range BeeTemplates {
if len(v.Templates()) != 4 {
t.Errorf("should be 4 but got %v", len(v.Templates()))
}
}
}